当前位置: 移动技术网 > IT编程>移动开发>Android > Android如何防止apk程序被反编译(尊重劳动成果)

Android如何防止apk程序被反编译(尊重劳动成果)

2019年07月24日  | 移动技术网IT编程  | 我要评论

夷陵中学彭春阳,巴布熊猫主题曲,临城租房

作为android应用开发者,不得不面对一个尴尬的局面,就是自己辛辛苦苦开发的应用可以被别人很轻易的就反编译出来。

google似乎也发现了这个问题,从sdk2.3开始我们可以看到在android-sdk-windows\tools\下面多了一proguard文件夹

proguard是一个java代码混淆的工具,通过proguard,别人即使反编译你的apk包,也只会看到一些让人很难看懂的代码,从而达到保护代码的作用。

下面具体说一说怎么样让sdk2.3下的proguard.cfg文件起作用,先来看看android-sdk-windows\tools\lib\proguard.cfg的内容:
复制代码 代码如下:

-optimizationpasses 5
-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontpreverify
-verbose
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*
-keep public class * extends android.app.activity
-keep public class * extends android.app.application
-keep public class * extends android.app.service
-keep public class * extends android.content.broadcastreceiver
-keep public class * extends android.content.contentprovider
-keep public class * extends android.app.backup.backupagenthelper
-keep public class * extends android.preference.preference
-keep public class com.android.vending.licensing.ilicensingservice
-keepclasseswithmembernames class * {
native <methods>;
}
-keepclasseswithmembernames class * {
public <init>(android.content.context, android.util.attributeset);
}
-keepclasseswithmembernames class * {
public <init>(android.content.context, android.util.attributeset, int);
}
-keepclassmembers enum * {
public static **[] values();
public static ** valueof(java.lang.string);
}
-keep class * implements android.os.parcelable {
public static final android.os.parcelable$creator *;
}

从脚本中可以看到,混淆中保留了继承自activity、service、application、broadcastreceiver、contentprovider等基本组件以及com.android.vending.licensing.ilicensingservice,
并保留了所有的native变量名及类名,所有类中部分以设定了固定参数格式的构造函数,枚举等等。(详细信息请参考<proguard_path>/examples中的例子及注释。)

让proguard.cfg起作用的做法很简单,就是在eclipse自动生成的default.properties文件中加上一句“proguard.config=proguard.cfg”就可以了

完整的default.properties文件应该如下:
复制代码 代码如下:

# this file is automatically generated by android tools.
# do not modify this file -- your changes will be erased!
#
# this file must be checked in version control systems.
#
# to customize properties used by the ant build system use,
# "build.properties", and override values to adapt the script to your
# project structure.
# project target.
target=android-9
proguard.config=proguard.cfg

大功告成,正常的编译签名后就可以防止代码被反编译了。反编译经过代码混淆的apk得到的代码应该类似于下面的效果,是很难看懂的:
 
如果您使用的是2.3之前的sdk版本也没关系,把上面的proguard.cfg文件复制一份放到项目中,然后进行相同的操作即可

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网