dexknife-wj
即将开源的项目
https://a.app.qq.com/o/simple.jsp?pkgname=com.wj.makebai
在另外一个仓库,可能会上传
个人精力有限,暂停项目升级,各个功能的支持请见链接。最后一次更新是 android studio 2.3,gradle 3.x
介绍
插件实现了加固部分的签名校验和 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 不用改。 项目文件可以修改加载策略和包名,其他不建议大改,如果你确实搞的定。
**未来的完善功能 添加更完善的加固方式,请期待。。。