前言
平时开发有很多测试期间需要写的代码(比如日志),如何不让其在正式环境下运行呢?或者不让其在正式环境下存在(防止反编译查到重要信息)
实现方法
1.通过混淆(废弃,因为需要打开优化开关,经测打开后会导致okhttp出现问题)
工具类示例: 这是一个打印当前堆栈信息的方法,可以用来跟踪调用栈,测试环境下运行没有问题,但是到正式环境下,会不断的创建String对象,并且调用打印方法消耗资源
object TestUtil {
/**
* 打印当前堆栈的调用信息
*/
fun printAllStackInfo() {
Log.e("printAllStackInfo","**********************************start")
Thread.getAllStackTraces()[Thread.currentThread()]?.forEach {
Log.e("printAllStackInfo",it.toString())
}
Log.e("printAllStackInfo","**********************************end")
}
}
通过配置混淆文件如下: 就可以在正式版中移除该方法
-assumenosideeffects class com.lt.androidkj.utils.TestUtil { # todo 改成自己的包名
public *** printAllStackInfo(...);
}
app.gradle中配置如下:
buildTypes {
release {
minifyEnabled true //混淆
shrinkResources true//混淆压缩代码
proguardFiles /*getDefaultProguardFile('proguard-android.txt'),参考 https://github.com/peerless2012/AndroidBasis/blob/master/problem/%E5%88%A9%E7%94%A8Proguard%E7%A7%BB%E9%99%A4%E6%97%A0%E7%94%A8%E4%BB%A3%E7%A0%81%E4%BB%A5%E5%8F%8A%E7%A2%B0%E5%88%B0%E7%9A%84%E5%9D%91.md*/ 'proguard-rules.pro'
}
}
2.通过系统配置
这种方式比较简单,可以改造上面的工具类,如下所示:
object TestUtil {
/**
* 打印当前堆栈的调用信息
*/
fun printAllStackInfo() {
if(!BuildConfig.DEBUG)//加了这个判断
return
Log.e("printAllStackInfo","**********************************start")
Thread.getAllStackTraces()[Thread.currentThread()]?.forEach {
Log.e("printAllStackInfo",it.toString())
}
Log.e("printAllStackInfo","**********************************end")
}
}
通过BuildConfig.DEBUG可以判断当前环境是否是测试环境
该方式比较简单,但是反编译后有几率可以被看到源码(BuildConfig.DEBUG后面的代码可能会被编译器优化掉),并且调用栈不会被移除
3.通过自定义配置gradle
第三种方式参考:Android中Release版本去掉Log的方法-CSDN博客
结语
该篇博客并没有提供工具类,而是提供了一种思路,可以自己封装一些工具类,并且开发更方便
比如日志系统,测试代码执行时间,打印堆栈,测试的toast等,如果有什么好的想法可以留言,让我也用上 \滑稽
对Kotlin或KMP感兴趣的同学可以进Q群 101786950
如果这篇文章对您有帮助的话
可以扫码请我喝瓶饮料或咖啡(如果对什么比较感兴趣可以在备注里写出来)