使用Xposed强制android WebView开启debug模式
使用Xposed强制android WebView开启debug模式
从 https://developer.chrome.com/devtools/docs/remote-debugging 我们可以知道在android 4.4+可以通过在apk中使用下面的代码开启webview的chrome远程调试
WebView.setWebContentsDebuggingEnabled(true);
但我们开发中接触的apk往往是第三方的,没谁会为我们开启webContentsDebuggingEnabled。而Xposed能强制做到这一点
Xposed
Xposed能够勾住(Hook) Android应用程序对象的方法,实现AOP,一个简单的例子:
public class WebViewHook implements IXposedHookLoadPackage { // handleLoadPackage 会在android加载每一个apk后执行 public void handleLoadPackage(LoadPackageParam lpparam) throws Throwable { // 可以从lpparam中获取当前apk的名字 if (! lpparam.packageName.equals("com.tencent.mobileqq")) { return; } XposedBridge.log("WebViewHook handleLoadPackage: " + lpparam.packageName); // 勾住 WebView 所有的构造器 XposedBridge.hookAllConstructors(WebView.class, new XC_MethodHook() { @Override protected void beforeHookedMethod(MethodHookParam param) throws Throwable { // 打开webContentsDebuggingEnabled XposedHelpers.callStaticMethod(WebView.class, "setWebContentsDebuggingEnabled", true); XposedBridge.log("WebViewHook new WebView(): " + packageName); } }); } }
上面的代码可以为QQ打开WebView的webContentsDebuggingEnabled Xposed工作原理可以参考文档: https://github.com/rovo89/XposedBridge/wiki/Development-tutorial 没有
详细的API可以查看源代码:
https://github.com/rovo89/XposedBridge/tree/master/src/de/robv/android/xposed
前期工作
1、需要android 4.4+ Root手机
2、安装 Xposed框架
3、已开启QQ WebView的Apk: webviewdebughook.Apk

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Android Studio下载地址
http://www.android-studio.org/ 1.使用模拟器,mac中必须配置的亮点: export ANDROID_HOME =~/Library/Android/sdk 将Android SDK写入到环境变量里 我的sdk路径是 /Users/sayid/sdj_sdk/sdk export PATH=${PATH}:${ANDROID_HOME}/tools 因为要用到adb的相关命令,所以也要加入到环境变量里,这个windows一般我也会配置的,React Native安装都是命令安装的,adb install 等这些命令肯定会用到。
- 下一篇
Android开发技巧——实现设计师给出的视觉居中的布局
本篇主要是对自定义控件的测量方法(onMeasure(int widthMeasureSpec, int heightMeasureSpec))在实际场景中的运用。 在移动应用的设计中,经常有这样的界面:某个界面的元素非常少,比如空列表界面,或者某某操作成功的界面,只有一两个元素在中间。但是它们在某个布局里又不是数学上的那个居中,而是经过设计师调出来的“视觉居中”。这种“视觉居中”内部是怎么计算的,我大致也不懂,反正结果就是设计师们看起来要显示的信息给人有感觉是在中间的(通常是比中间偏上一点)。 既是这样,那我们在布局中就不能用gravity="center"或layout_gravity="center"等这样的属性来设置了。而使用固定的padding或margin来调整它的位置,也难以在不同的屏幕分辨率中实现同样的效果,那就只好按钮设计图的标注,按比例来计算它的位置了。 按比例来调整子view与layout中的距离,在约束布局(ConstraintLayout)中是可以做到的,但是在我个人看来相对这样简单的需求,约束布局有点重了,并且它的依赖在不同方式的编译下总是很容易出问题(比如...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2整合Redis,开启缓存,提高访问速度
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- MySQL8.0.19开启GTID主从同步CentOS8
- Mario游戏-低调大师作品
- Linux系统CentOS6、CentOS7手动修改IP地址
- Docker安装Oracle12C,快速搭建Oracle学习环境
- CentOS7安装Docker,走上虚拟化容器引擎之路