我再也不能通过命令行或Eclipse使用ADB连接到我的设备了。
执行命令
adb devices
返回设备名称,但显示为脱机状态。
我尝试过的事情。
切换Android调试模式
重新安装谷歌USB驱动
将操作系统恢复到以前工作的备份(CyanogenMod)
换掉USB数据线
多次重启电话/电脑
更新Android SDK
我真的不知道发生了什么。你觉得我还能试什么,我洗耳恭听。
需要明确的是,如果你遇到了同样的问题,那么问题可能是SDK过时了。从4.2.2开始,有一个安全特性需要您确认连接设备的RSA指纹。打开SDK管理器并更新工具!然后重新启动。
不是真正的答案,但更有助于解决CM的明显问题。
我有一个HTC Inspire HD运行cm-11-20140309非官方BR1-ace(稳定版本)。我可以在更新之前使用adb,但我从来没有安装SDK,因为我不需要。以上所有方法我都试过了。
起初我以为我的问题是MTP驱动程序,但事实并非如此。在安装和更新SDK到包括4.4.2之后,HTC MTP设备驱动程序在通过USB连接时安装正常,但在新的SDK安装位置使用adb时,在MTP和ptp模式下,设备仍然显示为离线,同时调试和打开。当我关闭usb调试手机自动重启,我收到错误:
"不幸的是进程android.process.media已停止"
新的CM在developer options下有一个选项,可以启用通过WIFI进行调试,所以我也尝试了一下,结果显示无法连接到IP地址和端口。和其他海报一样,我能ping通IP地址。
我还检查了启用ADB和应用程序的根访问选项,因为它只设置为apps,当我使用ADB设备时,手机仍然显示离线,偶尔它会抛出如上所示的相同错误。
编辑:
现在,我的手机强制重新启动,我重新启动调试,插入并运行adb设备,最后手机提示我输入RSA密钥。由于某种原因,我之前没有收到提示,现在电话接通了。因此,问题可能是在重新启动后,需要将根访问权限从应用程序切换到应用程序和adb。
以下是它显示离线的原因:http://playingwithsid.blogspot.com/2013/05/android-device-offline-fixing-adb.html
好吧,这里没有巫毒,没有盲目尝试,(我希望)解释清楚的解决方案(对不起,我愤怒了,我试着用谷歌搜索解决方案几乎一整天都没有结果)。
首先,让我们了解一下adb与设备的通信方式:
https://android.googlesource.com/platform/system/core/+/master/adb/protocol.txt
简短的故事:主机adb在5037上建立服务器,通过tcp端口5555(默认)连接到设备上的adbd。
这意味着-为了工作,您的adb必须有一条通往本地5037和远程5555的清晰道路。
如果你不能或不想使用USB,你可以在设备上(使用设备终端)设置adbd来监听,而不需要建立USB连接:
setprop service.adb.tcp.port 5555
stop adbd
start adbd
使用netstat -plant | grep adbd检查adbd是否正在监听端口5555(或您选择的任何其他端口)。
现在使用捕获过滤器端口5555启动Wireshark。在您的主机上执行此命令:adb connect device_ip:5555(如果使用非标准端口则替换5555)。
根据上面的文档,您应该可以看到来自两个方向的CNXN命令!如果您的远端没有回复,adb设备将说您的设备离线!游戏结束了。Adb devices不做任何网络交换,它只是显示Adb connect命令的结果。
我的问题是——我一直在Virtualbox中运行Android,使用NAT网络和转发5555端口。另外,我在端口5554上运行了一个模拟器。它并没有占用5555,但不知为何,这两个干扰和中断了Virtualbox在较低级别的连接,因为我有很多奇怪的重复ack和rst在界面上飞来飞去。这个问题的解决方案是选择一个不同的端口。
如果我说错了请告诉我,但我以前没见过有人这么提议。也没有解释它应该如何工作以及为什么要工作。