调试Android WebView中的h5页面,一般就是经过alert和抓包工具来定位问题,效率低且没法直接调试样式或打断点,可谓是事倍功半。本文介绍一下我在项目中使用的新方法,可以经过chrome的开发工具在原生 Android 应用中调试 WebView。javascript
Android4.4+php
1.在APP中启用 WebView 调试,开启调试后,Chrome DevTools才能对WebView进行远程调试;java
WebView.setWebContentsDebuggingEnabled(true);
2.经过访问chrome://inspect/#devices访问已启用调试的 WebView 列表;android
3.调试Webview与远程调试普通页面相同,远程调试普通页面也就是在安卓手机中安装Chrome浏览器,使用USB 链接 PC,而后在 PC 的 Chrome 浏览器中打开 chrome://inspect/#devices 便可。git
若是团队中有Android开发人员可以提供测试包,只要在测试包中开启Webview的debug模式就能够了。github
对于线上的APP,通常debug开关都是关闭的,这就须要借助第三方工具,才能将debug开关打开,这个工具就是Xposed和WebviewDebugHook。chrome
Xposed是一个框架,可以集成不少功能模块,这些模块可以在不修改APK的状况下,修改APP的运行方式。这里咱们就须要WebviewDebugHook模块来开启APP的WebView debug模式。下面主要介绍一下安装的步骤:浏览器
(1)获取手机的root权限,这个推荐使用KingRoot,可能一次获取root权限会失败,建议失败后多试几回;app
(2)下载适合版本的Xposed和WebviewDebugHook,并安装。框架
目前Xposed的官网上给出的连接是这样的:
Android5.0+:https://forum.xda-developers.com/attachment.php
Android4.0.4-4.4.4:de.robv.android.xposed.installer_v33_36570c.apk
而WebviewDebugHook的安装文件是git项目https://github.com/feix760/WebViewDebugHook源码中的WebViewDebugHook.apk。
(3)激活Xposed和WebViewDebugHook模块
下图是Android5.0+下的截图,经过点击【安装/更新】激活Xposed,并切换菜单到模块功能,而后勾选上WebViewDebugHook。
安装完毕后,接下来就能够开开心心的调试Webview了。
另外还有两个小Tips:
(1)访问chrome://inspect/#devices若是chrome没有检测到Remote Target中的页面,可能须要安装一下chrome的ADB插件;
(2)对于腾讯系的APP,默认采用X5内核,须要将WebViewDebugHook的git目录下的debug.conf文件拷贝到SD卡的根目录下便可。