惊呆了:AI改了三个字节,修好了一个跑不起来的adb

我在一个老版本ubuntu上运行定制版adb,报下面的错误:

text 复制代码
$ adb -host connect 30.207.94.56:61101
* daemon not running. starting it now on port 6037 *
error: could not install *smartsocket* listener: Address family not supported by protocol
ADB server didn't ACK
* failed to start daemon *
error: cannot connect to daemon

报错信息丢给AI,AI很快诊断出是因为adb在创建server时使用了AF_INET6(IPv6),而我的ubuntu不支持IPv6。

为了解决这个问题,它首先查看了adb的help信息,看能不能设置只监听IPv4,没成功。

接下来它尝试写个动态库interceptor.so,动态库中hook系统函数socket和bind,强制使用IPv4,以LD_PRELOAD=./interceptor.so adb方式运行,这个思路是对的,但是用起来有点麻烦,而且要在我的ubuntu上下载Android交叉编译工具链,被我阻止了。

我以为它会就此放弃,哪想到它放大招了。

它直接反汇编了adb可执行程序,找到定义sockaddr的地方、调用函数socket和bind的地方:

文件偏移 指令 原始值 修改值 效果
0xfdcea movw $0xa,0x10(%rsp) 0x0a 0x02 sockaddr family: AF_INET6→AF_INET
0xfdd05 mov $0xa,%edi 0x0a 0x02 socket() domain: AF_INET6→AF_INET
0xfdd46 mov $0x1c,%edx 0x1c 0x10 bind() addrlen: 28→16

然后通过下面的脚本,改了我的adb可执行文件:

python 复制代码
with open('~/adb', 'rb') as f:
    data = bytearray(f.read())

data[0xfdcea] = 0x02   # AF_INET  ← sockaddr family: AF_INET6(10) → AF_INET(2)
data[0xfdd05] = 0x02   # AF_INET  ← socket() domain: AF_INET6(10) → AF_INET(2)
data[0xfdd46] = 0x10   # sizeof(sockaddr_in) ← bind() addrlen: 28 → 16

with open('~/adb', 'wb') as f:
    f.write(data)

我简直惊呆了,打死我也想不出这种解决方法,关键是修改后的adb在这个ubuntu上还真能用了!

Linux平台的可执行文件没有完整性(防篡改)保护,所以修改后的文件能运行。

相关推荐
threerocks3 小时前
什么?我连 A2A、MCP 都没学会,现在又来了 AG-UI、A2UI.
前端·aigc·ai编程
Coffeeee3 小时前
两个例子,帮你快速理解什么是Token
人工智能·程序员·ai编程
饼干哥哥3 小时前
用AI全自动剪辑,日更 100条爆款视频——HyperFrames、Remotion、Git使用入门
人工智能·机器学习·ai编程
牛奶4 小时前
连微软都用不起 AI 了
aigc·openai·ai编程
MomentYY4 小时前
AI 到底是“懂”,还是在“猜”?
前端·人工智能·ai编程
沉默王二5 小时前
震惊!Claude Code这五个核心概念我居然才知道!
agent·ai编程·claude
身披彩云济沧海5 小时前
Trae 中配置 codegraph MCP
ai编程
贵慜_Derek6 小时前
复杂系统没法一把梭重构:Semi-Autoresearch 怎么小步迁移还不掉功能
人工智能·agent·ai编程