iOS 逆向编程(九 - 1)通过 USB 连接登录 iPhone 以及端口映射

一、简介
  • 之前操作都是通过 客户端(MAC)服务端(iPhone) 处于同一个 Wifi 下通过 SSH 进行连接。

  • 这种方式有个问题,就是网速不是很好的时候,输入一个命令会等一会才会显示,因为你输出成功了需要网络同步到手机上,你这边才会显示。

  • 如果通过 USB 连接两者将 SSH 传到 服务端(iPhone) 就不会有这个问题了,效率也高。

二、端口介绍
  • 端口就是设备对外提供服务的窗口,每个端口都有个端口号(范围是 0~65535,共 65536 个)

  • 有些端口号是保留的,已经规定了用途,比如:

    • 更多的保留端口号:服务端口号列表
    • 21 端口提供 FTP 服务
    • 80 端口提供 HTTP 服务
    • 22 端口提供 SSH 服务(可以查看 /etc/ssh/sshd_configPort 字段)
    // 进入服务端(手机)
    dengzemiaodeMacBook-Pro:.ssh dengzemiao$ ssh root@10.0.89.184
    // 进入 /etc/ssh 文件夹
    iPhone:~ root# cd /etc/ssh
    // 查看文件夹
    iPhone:/etc/ssh root# ls -l
    total 572
    -rw-r--r-- 1 root wheel 577388 Jan  4  2020 moduli
    -rw-r--r-- 1 root wheel   1526 Mar 21  2018 ssh_config
    -rw-r--r-- 1 root wheel   3228 Mar 31  2019 sshd_config
    // 查看 sshd_config 服务端配置文件
    iPhone:/etc/ssh root# cat sshd_config
    .....省略上下内容
    #Port 22 // 这个就是指定的端口号
    #AddressFamily any
    #ListenAddress 0.0.0.0
    #ListenAddress ::
    .....省略上下内容
    
  • iPhone 默认是使用 22 端口进行 SSH 通信,采用的是 TCP 协议。

三、WifiUSB 连接的区别与思路
  • Wifi 连接

    • 由于 SSH 走的是 TCP 协议,客户端(电脑)直接以 SSH 的方式通过 网络(Wifi) 登录到 服务端(iPhone),相当于 电脑 是通过 SSH 的方式直接访问 22 端口连接了手机。

  • USB 连接

    • Mac 上有个服务程序 usbmuxd (它会开机自动启动) ,可以将 Mac 的数据通过 USB 传输到 iPhone

      // usbmuxd 服务程序存放路径
      /System/Library/PrivateFrameworks/MobileDevice.framework/Resources/usbmuxd
      
    • USB 连接则不能直接通过 SSH 网络访问 22 端口这么干了。

    • 流程应该是通过 SSH 访问本机的其他窗口(只要不是 保留端口 即可,举例:10010),然后在由这个端口通过 usbmuxd 连接服务端(手机)的 22 端口,将数据传递过去,这样就避开了通过网络访问 22 端口了。

    • 需要将 客户端(电脑)10010 端口映射到 服务端(手机)22 端口上,端口映射完毕后,以后如果想跟 服务端(手机)22 端口通信,直接跟 客户端(电脑) 本地的 10010 端口通信就可以了。

四、端口映射

  • (可选)可以删掉其他所有文件,只保留这两个文件也可以的,不删也不妨碍,cd 到里面文件夹也是一样的。

  • 服务端(手机)22 端口 ( SSH端口 ) 映射到 客户端(电脑)本地的 10010 端口。

    • 进入文件夹 usbmuxd

      $  cd /Users/dengzemiao/Downloads/usbmuxd
      
    • 执行映射命令,将 服务端(手机)22端口与 客户端(电脑) 本地的 10010 端口建立映射连接关系,以后访问本地的 10010 端口访问的就是 服务端(手机)22 端口。

      // (推荐)加 -t 指令,支持电脑连接多台手机设备,也就是支持多个连接
      $ python tcprelay.py -t 22:10010
      
      // 不加 -t 指令,每次只能支持一个设备连接
      $ python tcprelay.py 22:10010
      
    • 命令输入之后,处于这样的状态就是连接成功了,这个映射窗口是不能关闭的,,关闭就映射关系取消了,所以做别的操作我们就需要新开一个终端窗口了。

    • 映射成功之后,我们将不能在用 $ ssh root@10.0.89.184 这种访问方式了,这种是网络访问方式,现在我们需要访问本地的 10010 端口即可,在新开终端窗口输入:

      // 将 IP 地址换成 localhost, -p 是端口号的意思
      $ ssh -p 10010 root@localhost
      
      // 将 localhost 等于 127.0.0.1
      $ ssh -p 10010 root@127.0.0.1
      
      // 也可以将 -p 10010 写在后面,可以通过 $ ssh --help 查看书写规则
      $ ssh root@localhost -p 10010
      

      如果报错 ssh_exchange_identification: read: Connection reset by peer, 检查一下 USB 是否连接了手机,确定电脑 USB 只连接了越狱手机,如果连接了多台手机或非越狱手机会报这个错误。

      // 连接 localhost 的 10010 端口
      dengzemiaodeMacBook-Pro:~ dengzemiao$ ssh -p 10010 root@localhost
      The authenticity of host '[localhost]:10010 ([127.0.0.1]:10010)' can't be established.
      RSA key fingerprint is SHA256:TmFvst8CU2JJqrFZ1QIANzprd1rUckdYjV4lcVaS8Gk.
      // 跟之前 Wifi 网络连接一下,询问是否确定连接并存储授权公钥
      Are you sure you want to continue connecting (yes/no)? yes
      // 成功连接
      Warning: Permanently added '[localhost]:10010' (RSA) to the list of known hosts.
      iPhone:~ root# 
      iPhone:~ root# exit
      logout
      Connection to localhost closed.
      

      通过 USB 连接的环境下,你输入任何命令都会迅速响应或显示出来,不会像之前 Wifi 连接的一样,输入命令之后会有延迟,而且在这个链接终端窗口上的每一次链接或者操作,映射那个终端窗口都会有数据输出。

五、通过 USB 拷贝传输文件、数据
  • Wifi 传递命令:$ scp ~/.ssh/id_rsa.pub root@10.0.89.184:~/.ssh

    dengzemiaodeMacBook-Pro:.ssh dengzemiao$ scp ~/.ssh/id_rsa.pub root@10.0.89.184:~/.ssh
    // 这里需要输入密码,是因为我们上面第一步就将之前的授权文件删除了,所以现在是没有免密登录的了
    root@10.0.89.184's password: 
    id_rsa.pub                                  100%  403    10.1KB/s   00:00    
    dengzemiaodeMacBook-Pro:.ssh dengzemiao$ 
    
  • USB 传递命令:$ scp -P 10010 ~/.ssh/id_rsa.pub root@localhost:~/.ssh

    • scp -P 10010 是固定格式,指定端口,可以通过 $ scp --help 进行查看,

    • root@localhost 也就是将 IP 地址换成 localhost 本地,然后本地走 10010 端口。

    • 下面的传输速度与上面 Wifi 的传输输度比较一下。

    dengzemiaodeMacBook-Pro:~ dengzemiao$ scp -P 10010  ~/.ssh/id_rsa.pub root@localhost:~/.ssh
    id_rsa.pub                                       100%  403   137.7KB/s   00:00 
    
  • 现在的这种方式,都是依赖于映射,但是只要关了映射那个窗口,映射关系就会消失,所以每次需要重新按上面的方式添加映射在进行连接。

  • 下一章会专门将这个映射命令写成 sh脚本 (shell) 使用,然后只需要执行这些脚本文件即可,会比每次都去拖拽文件执行映射命令方便。

  • 也看看 sh脚本 的简单编写与使用。

  • iOS 逆向编程(九 - 2)将端口映射、USB连接手机封装成 .sh 脚本

五一放假,出门在外,有时候没有WiFi,没法通过无线sshiOS中调程序,怎么办呢?好在大神Nikias Bassen(即@pimskeks5)写了一个可以把本地OSX/Windows端口转发到远程iOS端口的工具usbmuxd16,使我们能够通过USB连接线sshiOS中,大大增加了ssh连接的速度,也方便了那些没有WiFi的朋友。下面我们就简单介绍一下怎么使用神器usbmuxd。(注:以下操作在OSX中进行,Windows用户请自行安装python环境) 下载usbmuxd 从这里下载usbmuxd(http://cgit.sukimashita.com/usbmuxd.git/snapshot/usbmuxd-1.0.8.tar.gz),解压到本地。我们要用到的只有python-client目录下的tcprelay.py和usbmux.py两个文件,把它们放到同一个目录下,如笔者的 /Users/snakeninny/Code/USBSSH/ 使用usbmuxd usbmuxd的用法比较简单,在Terminal中输入 /Users/snakeninny/Code/USBSSH/tcprelay.py -t 远程iOS上的端口:本地OSX/Windows上的端口 即可把本地OSX/Windows上的端口转发到远程iOS上的端口,如 /Users/snakeninny/Code/USBSSH/tcprelay.py -t 22:2222 可把本地的2222端口转发到iOS上的22端口,那么直接 ssh root@localhost -p 2222 即可sshiOS中。 使用场景举例 完全脱离WiFi,使用USB连接iOS,用lldb调试SpringBoard。 i) 把本地2222端口转发到iOS的22端口 /Users/snakeninny/Code/USBSSH/tcprelay.py -t 22:2222 ii) ssh过去并用debugserver attach到SpringBoard ssh root@localhost -p 2222 debugserver *:1234 -a "SpringBoard" iii) 把本地1234端口转发到iOS的1234端口 /Users/snakeninny/Code/USBSSH/tcprelay.py -t 1234:1234 iv) 用lldb开始调试 lldb process connect connect://localhost:1234
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡尔特斯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值