我再也不能通过命令行或Eclipse使用ADB连接到我的设备了。

执行命令

adb devices

返回设备名称,但显示为脱机状态。

我尝试过的事情。

切换Android调试模式 重新安装谷歌USB驱动 将操作系统恢复到以前工作的备份(CyanogenMod) 换掉USB数据线 多次重启电话/电脑 更新Android SDK

我真的不知道发生了什么。你觉得我还能试什么,我洗耳恭听。

需要明确的是,如果你遇到了同样的问题,那么问题可能是SDK过时了。从4.2.2开始,有一个安全特性需要您确认连接设备的RSA指纹。打开SDK管理器并更新工具!然后重新启动。


当前回答

尝试重新启动adb服务器,操作如下:

adb kill-server

adb start-server

我也遇到过和你一样的问题。重新启动adb服务器将解决此问题。

其他回答

但我找到了最简单的方法 只需进入DDMS并按照图中所示进行操作…

这很可能是由于过时的adb流程。 这可能是因为蹩脚的开发人员将adb和dll打包并安装在Windows的根目录中。例如C:\Windows\adb.exe

打开任务管理器kill adb.exe,将adb.exe定位在root:\Windows并删除它。然后使用最新的SDK

对我来说很管用:一开始很管用,但过了一段时间就下线了。 我做了以下事情: 亚行kill-server 亚洲开发银行启动服务器。 再次用usb连接电脑 亚洲开发银行设备, 提供的空列表的输出。 Adb tcpip 5555, Adb connect <移动wifi IP地址> 然后它又上线了。

好吧,这里没有巫毒,没有盲目尝试,(我希望)解释清楚的解决方案(对不起,我愤怒了,我试着用谷歌搜索解决方案几乎一整天都没有结果)。

首先,让我们了解一下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在界面上飞来飞去。这个问题的解决方案是选择一个不同的端口。

如果我说错了请告诉我,但我以前没见过有人这么提议。也没有解释它应该如何工作以及为什么要工作。

我认为最好的方法是先禁用设备,然后从设备管理器中启用设备,然后运行adb devices命令。

转到开始选项卡,右键单击计算机 从下拉菜单中,单击Manage 在计算机管理界面中,单击“设备管理器” 在右侧窗格中,展开便携式设备以找到您的设备 右键单击设备名称,然后在下拉菜单中单击“禁用” 当它被禁用时,除了启用它外,请重复步骤5。

设备将重新上线。这是更快。