IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Android代码保护与反调试方案 -> 正文阅读

[移动开发]Android代码保护与反调试方案

1、代码保护方案

1.1、Proguard代码混淆

ProGuard是一个开源的Java代码收缩器,优化器,混淆器和预校验器,ProGuard的作用如下:
(1)压缩(Shrink):检查并移除代码中无用的类、字段、方法;
(2)优化(Optimize):对字节码进行优化,移除无用的指令;
(3)混淆(Obfuscate):使用a,b,c,d这样简短而无意义的名称,对类、字段和方法进行重命名;
(4)预检(Preverify):在Java平台上对处理后的代码进行预检;

经过Proguard处理后的程序逻辑与之前完全一致,而混淆后的代码即便反编译也很难阅读。同时,在混淆过程中对于一些不影响正常运行的信息将永久丢失,这些信息的丢失使得程序更加难以理解。Proguard代码混淆并不能完全避免反编译,经过apktool、dexToJar、jd-gui等反编译工具依然能得到大部分源码。

1.2、Dex加壳

加固方案

? 1.源APK文件存放在壳APK的资源目录asset下;

? 2.使用DexClassLoader动态加载源APK,并运行;

步骤如下:

1、重写Application

默认情况一个android 应用程序启动一个默认的Application 对象, 我们需要在壳apk启动时动态加载源apk。因此我们需要重写Application的attachBaseContext或者onCreate,在其中加载源apk。

2、释放资源中源APK到目标目录下

在Application的attachBaseContext或者onCreate中拷贝asset中的源apk到目标目录下。

3、在壳apk中通过DexClassLoader加载源apk并运行目标activity,同时销毁壳apk中的activity

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        String dexPath = "";
        String optimizedDirectory = "";
        String librarySearchPath = "";
        ClassLoader parent = getClassLoader();
        DexClassLoader dexClassLoader = new DexClassLoader(dexPath,optimizedDirectory,librarySearchPath,parent);
        try {
            //启动源apk中的目标activity
            Class desActivity = dexClassLoader.loadClass("destination.destActivity");
            Intent intent = new Intent(this,desActivity);
            startActivity(intent);
            //销毁壳apk中的activity
            finish();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

1.3、虚拟机源码保护

虚机源码保护为用户提供一套完整的工具链,首先把用户待保护的核心代码编译成中间的二进制文件,随后生成独特的虚机源码保护执行环境和只能在该环境下执行的运行程序。

虚机源码保护会在App内部隔离出独立的执行环境,该核心代码的运行程序在此独立的执行环境里运行。即便App本身被破解,这部分核心代码仍然不可见。

undefined

?

2、反调试方案

2.1、Debug#isDebuggerConnected是否有调试器挂载到程序上

    /**
     * Determine if a debugger is currently attached.
     */
    public static boolean isDebuggerConnected() {
        return VMDebug.isDebuggerConnected();
    }

isDebuggerConnected函数用于检测此刻是否有调试器挂载到程序上,如果返回值为true则表示此刻被调试中。

if (Debug.isDebuggerConnected()){
            android.os.Process.killProcess(android.os.Process.myPid());
}

2.2、AndroidManifest.xml清单文件中加入android:debuggable="false"属性,使程序不能被调试

2.3、APK签名检测

Android SDK中有apk 签名检测的方法,Framework的PackageManager类提供了getPackageInfo()函数,

第二个参数传入GET_SIGNATURES时,返回对象的signature字段就是签名信息,计算其hash值,前后对比hash值。实际可用的两种方案:

(1)在本地Java代码里进行校验,不一致则强退应用;

(2)把签名信息发到服务器后台,服务器后台记录着正确的签名信息,比对后不一致则返回一个错误给错误

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-12-25 11:21:31  更:2022-12-25 11:23:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/27 17:08:37-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码