Android如何防止apk程序被反编译(尊重劳动成果)
程序员文章站
2023-12-02 20:03:10
作为android应用开发者,不得不面对一个尴尬的局面,就是自己辛辛苦苦开发的应用可以被别人很轻易的就反编译出来。google似乎也发现了这个问题,从sdk2.3开始我们可...
作为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文件复制一份放到项目中,然后进行相同的操作即可
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文件复制一份放到项目中,然后进行相同的操作即可