美文网首页
WebView-骚操作03-Hook

WebView-骚操作03-Hook

作者: 肥牛大猛 | 来源:发表于2020-12-28 19:14 被阅读0次

android5.0以上,webview所在进程如果是android.uid.system,运行则会直接崩溃。
解决方法:

  1. 2个apk,由主apk做需要system权限的业务,拉起webview apk
  2. 通过hook方式解决,参考android.webkit.WebViewFactory源码,详细代码如下
public class WebViewUtils {

    private static final String TAG = "WebViewUtils";

    public static void hookWebView() {
        final int uid = android.os.Process.myUid();
        if (uid != android.os.Process.SYSTEM_UID) {
            Log.e(TAG, "uid=" + uid + ";not SYSTEM_UID;need not hook");
            return;
        }
        int sdkInt = Build.VERSION.SDK_INT;
        try {
            Class<?> factoryClass = Class.forName("android.webkit.WebViewFactory");
            Field field = factoryClass.getDeclaredField("sProviderInstance");
            field.setAccessible(true);
            Object sProviderInstance = field.get(null);
            if (sProviderInstance != null) {
                Log.i(TAG, "sProviderInstance!=null;need not hook");
                return;
            } else {
                Log.i(TAG, "sProviderInstance==null;need hook");
            }

            Method getProviderClassMethod;
            if (sdkInt > 22) {
                getProviderClassMethod = factoryClass.getDeclaredMethod("getProviderClass");
            } else if (sdkInt == 22) {
                getProviderClassMethod = factoryClass.getDeclaredMethod("getFactoryClass");
            } else {
                Log.i(TAG, "sdkInt:" + sdkInt + ";need not Hook");
                return;
            }
            getProviderClassMethod.setAccessible(true);
            Class<?> factoryProviderClass = (Class<?>) getProviderClassMethod.invoke(factoryClass);
            Class<?> delegateClass = Class.forName("android.webkit.WebViewDelegate");
            Constructor<?> delegateConstructor = delegateClass.getDeclaredConstructor();
            delegateConstructor.setAccessible(true);
            if (sdkInt < 26) {
                //低于Android O版本
                Constructor<?> providerConstructor = factoryProviderClass.getConstructor(delegateClass);
                if (providerConstructor != null) {
                    providerConstructor.setAccessible(true);
                    sProviderInstance = providerConstructor.newInstance(delegateConstructor.newInstance());
                }
            } else {
                String chromiumMethodNameStr = null;
                try {
                    Field chromiumMethodName = factoryClass.getDeclaredField("CHROMIUM_WEBVIEW_FACTORY_METHOD");
                    chromiumMethodName.setAccessible(true);
                    chromiumMethodNameStr = (String) chromiumMethodName.get(null);
                } catch (Exception e) {
                    Log.e(TAG, "can not found CHROMIUM_WEBVIEW_FACTORY_METHOD;use create");
                }
                if (chromiumMethodNameStr == null) {
                    chromiumMethodNameStr = "create";
                }
                Method staticFactory = factoryProviderClass.getMethod(chromiumMethodNameStr, delegateClass);
                if (staticFactory != null) {
                    sProviderInstance = staticFactory.invoke(null, delegateConstructor.newInstance());
                }
            }
            if (sProviderInstance != null) {
                field.set("sProviderInstance", sProviderInstance);
                Log.i(TAG, "Hook success!");
            } else {
                Log.i(TAG, "Hook failed!");
            }
        } catch (Throwable e) {
            Log.w(TAG, e);
        }
    }
}

相关文章

  • WebView-骚操作03-Hook

    android5.0以上,webview所在进程如果是android.uid.system,运行则会直接崩溃。解决...

  • 骚操作

    文‖茹云 心里想说,却被人生生贴胶带,本来以为可以诉说一下心里的难受与舒服,结果被这样的骚操作,一阵懵逼。 不知道...

  • 骚操作

    突然想哭的时候,你会有哪些操作? 成年人的世界不容易呀,总有那么几个瞬间特别想哭,那么你们有什么样的骚操作呢? 支...

  • 骚操作

    先说下近期的三个项目,这三个项目是造成我骚操作的主要原因。近期的三个项目分别是: A、5月13日-5月20...

  • 骚操作

    无语仰望天。 就在风向晚为自己回国后的经历感到无奈至极时,一道痞坏痞坏的声音幽幽传来。 “嘿,美女,喜欢喝奶茶?哥...

  • 骚操作

    一路上,沈青石都保持了沉默闭目养神,不言不语。这在秦子衿的眼里,他是又恢复了病弱清冷的模样。 直到车子驶入天玺沈宅...

  • 骚操作

    不知简书啥时新开了"骚操作":随时给你一脸的烂广告,喊你点点点,不点还不行!刚开始还怀疑是我的手机中了毒,后来发现...

  • linux常用命令

    grep管道 分屏操作 基础命令 骚操作

  • 【转】JavaScript遍历、枚举、迭代

    原文链接:JavaScript骚操作之遍历、枚举与迭代(上篇)JavaScript骚操作之遍历、枚举与迭代(下篇)...

  • Python极限操作流:控制Excel实现自动化办公!

    Python骚操作:Python控制Excel实现自动化办公! 1.安装 Python骚操作:Python控制Ex...

网友评论

      本文标题:WebView-骚操作03-Hook

      本文链接:https://www.haomeiwen.com/subject/spmtoktx.html