dexknife-wj

简介:Android Studio 下的 apk 加固插件,支持签名校验和 dex 加密
更多:作者   提 Bug   
标签:
apk加固-

介绍
插件实现了加固部分的签名校验和 dex 分包加载,dex 加密等,其余功能是多渠道打包和自定义分包 先说说写这个插件的目的,其实就是第三方加固不方便还要钱,没有插件打包方便集成,最主要的是不知道别人怎么弄的出现 bug 和修改需求不方便,所以我就写了个插件,虽然是基础加固但是好过只能用混淆简单保护代码要好,最主要是自己可以随意改。当然还集成分包和多渠道打包的插件功能。 默认是要使用分包和多渠道打包的,资源混淆在 1.1.0 上新加,默认不开启需要自己开启。
感谢
packer-ng-plugin 版本 1.0.8,多渠道打包
Android-Easy-MultiDex版本 1.0.1,分包
ApkToolPlus加固
AndResguard资源混淆
使用方法可以参见上述的项目,本插件略微有些改动。详情见说明或者 demo 或者源码

更新说明 1.1.1
1.更新加密方式,加固之后压缩体积大幅度缩小,转移到这个版本请更新 jiagu.zip。
2.添加自动打包成 jiagu.zip 的执行类。暂时不支持命令,请查看 OutShellZip.java
3.优化部分流程
1.1.0
1.修改了单独加固方式 需要在 gradle wjshell 点击有对应 apk 的 task
2.新增了 shellname 的修改,可以自己定义修改后的名称
3.最主要的是新加了资源混淆,主要用到了 andresguard 的混淆代码,需要配置文件 andreshuard.xml 和 resource_mapping.txt,具体查看 demo 或者 andresguard
1.0.3
去掉了多余加固 兼容 gradle3.3**


用法介绍

dependencies {
   classpath 'com.library.wj:dexknife-wj:1.1.1'//分包
}

使用插件

apply plugin: 'dexknifeWj'

接下来是配置

dexKnife {
    //必选参数
    enabled true //if false,禁用分包插件
    //可选参数/
    //1.如果没有可选参数,将根据 enabled 决定是否分包。
    //2.如果有可选参数,需满足必选参数和可选参数的条件才允许分包

    /*
    *eg:当前 productFlavors = dev,buildType = debug,
    *参数组合 1:enabled = true,productFlavor = dev,buildType = debug 分包
    *参数组合 2:enabled = true,productFlavor = mock,buildType = debug 不分包
    *参数组合 1:enabled = true,buildType = debug 所有 buildType = debug 分包
    *参数组合 1:enabled = true,productFlavor = dev 所有 productFlavor = dev 分包
    * */
    //=======================加固
    shell true
    andresguard true//是否开启资源混淆
    packerNgShell false
    shellname ''
    apktoolpath 'C://android_work/android_workspace/android_studio_xs/dexknife-wj/src/apktool/apktool.jar'
    jiaguzippath 'C:/android_work/android_workspace/android_studio_xs/dexknife-wj/src/main/java/com/wj/dexknife/shell/jiagu/jiagu.zip'
    //=======================多渠道
    // 指定渠道打包输出目录
    archiveOutput = file(new File(project.buildDir.path, new SimpleDateFormat("yyyy-MM-dd").format(new Date()) + "_apks"))
    // 指定渠道打包输出文件名格式
    // 默认是 `${appPkg}-${flavorName}-${buildType}-v${versionName}-${versionCode}`
    archiveNameFormat = 'qianfandu-${flavorName}-${versionName}'
    // 是否检查 Gradle 配置中的 signingConfig,默认不检查
    // checkSigningConfig = false
    // 是否检查 Gradle 配置中的 zipAlignEnabled,默认不检查
    // checkZipAlign = false
}

其中加固注释的是加固所要填的,其他配置请见其他两个插件的写法。 apktoolpath 是打包工具 jiaguzippath 是壳的文件 只个文件后面介绍 shell 是编译时打包 packerNgShell 是配合多渠道打包用的 就是 packer-ng 这个插件,默认是集成了的 application '你的壳的 application 名称' andresguard true or false 是否开启混淆 shellname '' 可填可不填 设置加固打包的名称
命令打包方式
1.加固(请在 jdk bin 目录下执行,有好的改进请留言)

命令说明 java -jar jar 路径 签名文件路径 keystorePassword aliasPassword alias 加固后缀名 apktool.jar 路径 jiagu.zip 路径 要加固的 apk 路径 是否资源混淆(可以不填,不填默认是 false,如果填写请填后面的剩下参数) 资源混淆白名单 resmap
例子 java -jar D:\wangjun\github\dexknife-wj2\dexknife-wj-1.1.1.jar D:\wangjun\github\dexknife-wj2\test.jks 123456 123456 test _  D:\wangjun\github\dexknife-wj2\apktool.jar D:\wangjun\github\dexknife-wj2\jiagu.zip D:\wangjun\github\dexknife-wj2\app\build\outputs\apk\app-debug.apk true D:\wangjun\github\dexknife-wj2\app\andreshuard.xml D:\wangjun\github\dexknife-wj2\app\resource_mapping.txt

2.制作 jiagu.zip 即是壳文件

命令说明 java -cp jar 路径 加壳的方法 制作壳文件工作的路径 需要制作成壳文件的 apk 路径 输出的文件夹  apktool 路径
例子 java -cp C:\Users\MoreStrongW\Desktop\dexknife-wj-1.1.1.jar ml.OutShellZip C:\Users\MoreStrongW\Desktop\deco D:\wangjun\github\dexknife-wj2\myapplication\build\outputs\apk\myapplication-debug.apk  C:\Users\MoreStrongW\Desktop\1213 D:\wangjun\github\dexknife-wj2\apktool.jar

好了上效果图

没有加固之前的
这里写图片描述 加固之后的
这里写图片描述 区别在于 你只看的到壳文件 原项目的 dex 加密了放在 asset 了。动态加载了 dex 和分包是一样的 只不过是解密要点时间。
如果要自定义加壳文件请在配置文件加上 application '你的壳的 application 名称'
单独加固需要点击 task 如图 这里写图片描述 多渠道打包敲命令 和 packer-ng 插件一样 gradlew clean apkRelease 请注意要配置签名 和 普通配置没有什么不同

demo 请注意修改 apktoolpath jiaguzippath 和签名 在项目里面已经加了所需的资源包请修改路径即可

关于壳文件的制作 myapplication 项目是壳文件的项目 build 之后有 apk,用 ApkToolPlus 反编译得到文件,按照 jiagu.zip 的结构即可。 apktool.jar 不用改。 项目文件可以修改加载策略和包名,其他不建议大改,如果你确实搞的定。

**未来的完善功能 添加更完善的加固方式,请期待。。。

Android 开发经验分享
C 轮融资近 30 亿元理财推荐
Android 开发经验分享
C 轮融资近 30 亿元理财推荐