markexin / markexin.github.io

Keep learning......
4 stars 0 forks source link

通过 Chrome devtools protocol 和 adb 调试 Android Webview #6

Open markexin opened 9 months ago

markexin commented 9 months ago

【摘录】https://www.cnblogs.com/kenkofox/p/15162045.html

前提条件:usb 连接手机,adb 能查找到 devices,如果有问题,多拔插几次,确认授权。

第一步,确认安卓 App 编译时已经启用了webview 允许调试(一般是允许的,可以通过连接usb,打开chrome的inspect页面(chrome://inspect/#devices),能连上就表示允许调试了) image

第二步,查找进程 pid 使用命令: adb shell grep -a webview_devtools_remote /proc/net/unix image

第三步,绑定进程消息到电脑的端口 使用命令: adb forward tcp:9222 localabstract:webview_devtoolsremote{pid} image

第四步,验证绑定情况。 使用命令: curl localhost:9222/json/version image

使用命令: curl localhost:9222/json/list 可以获得当前网页信息和调试用的websocket链接 image

第五步,通过websocket发送CDP(chrome devtools protocol)指令(使用上述 list 出来的页面 webSocketDebuggerUrl) 下边的是 nodejs 代码,引用了 ws npm包。

var wsURL = 'ws://127.0.0.1:9222/devtools/page/F4C53489B38E9B2785C62085DCB75FB9';
function ws() {
    var WebSocket = require('ws');
    const ws = new WebSocket(wsURL);

    ws.on('open', function open() {
        ws.send(JSON.stringify({"id": 1, "method": "Runtime.evaluate", "params": {"expression": "window.location.toString()"}}));
    });

    ws.on('message', function incoming(message) {
        console.log('received: %s', message);
    });
}
ws();

打印结果:received: {"id":1,"result":{"result":{"type":"string","value":"https://games.shopee.co.id/pet/?activity=23cb19698abc84fa"}}}

再往后,可以使用一些现成的高级别api库,例如puppeteer实际就是基于CDP的一个库,但它只支持内置的chromium,无法用来调试外部浏览器。 按介绍说,https://github.com/cyrus-and/chrome-remote-interface 是一个相关的库,但实际使用时总无法连上ws。

如果直接更成熟的整套体系,例如 Appium,那就更方便了,这种工具已经把上述流程都内置了,参考:https://appium.io/docs/en/writing-running-appium/web/hybrid/

参考资料: https://github.com/cyrus-and/chrome-remote-interface/ https://chromedevtools.github.io/devtools-protocol/ https://testerhome.com/topics/19461