使用proguard混淆打包APK keystore的创建

使用proguard混淆打包APK

     在打包发布android应用的时候,可以应用proguard来对代码进行混淆,防止有人反编译apk获取源代码。

     之前创建android 2.3的项目的时候,会在根部录下自动创建proguard.cfg文件,4.0之后需要手动创建。

     在工程中添加proguard.cfg,内容如下:

-optimizationpasses 5
-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontpreverify
-ignorewarnings 
-dontwarn   
-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>;
}

-keepclasseswithmembers class * {
    public <init>(android.content.Context, android.util.AttributeSet);
}

-keepclasseswithmembers class * {
    public <init>(android.content.Context, android.util.AttributeSet, int);
}

-keepclassmembers class * extends android.app.Activity {
   public void *(android.view.View);
}

-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

-keep class * implements android.os.Parcelable {
  public static final android.os.Parcelable$Creator *;
}

上面的代码可以用于调用第三方包的情况。


然后在项目的project.properties文件中添加:

proguard.config=proguard.cfg   


项目上右击->Android Tools->Export Signed .....输入密码就可以了

使用proguard混淆打包APK keystore的创建_第1张图片


如果没有keystore的话需要自己创建。

然后一路下一步,点finish,结果报错

conversion to dalvik format failed with error 1

原因是proguard版本的问题。

去http://proguard.sourceforge.net/下载最新版proguard


解压后将其中的lib和bin两个目录拷贝到/Your android sdk/tools/proguard文件夹下.


再Export一下,成功!



keystore的创建问题


一、Android Apk签名 
Apk签名首先要有一个keystore的签名用的文件。 
keystore是由jdk自带的工具keytool生成的。 
具体生成方式参考: 
开始->运行->cmd->cd到你安装的jdk的目录里,我的是C:\Program Files\Java\jdk1.6.0_10\bin 
然后输入: 
keytool -genkey -alias asaiAndroid.keystore -keyalg RSA -validity 20000 -keystore asaiAndroid.keystore 
-alias 后面跟的是别名这里是 asaiAndroid.store 
-keyalg 是加密方式这里是RSA 
-validity 是有效期 这里是20000 
-keystore 就是要生成的keystore的名称 这里是asiAndroid.keystore 
然后按回车键 
按回车后首先会提示你输入的密码:这个在签名时要用的,要记住 
然后会再确认你的密码。 
之后会依次叫你输入姓名、组织单位、组织名称、城市区域、省份名称、国家代码(CN)等。 

开始签名。 
在 C:\Program Files\Java\jdk1.6.0_10\bin 还提供一个工具 jarsigner.exe 
运行命令给APK签名: 
jarsigner -verbose -keystore asaiAndroid.keystore -signedjar Lotteryonline_signed.apk LotteryOnline.apk asaiAndroid.keystore 
-keystore: keystore的名称 
LotteryOnline_signed.apk: 签名后的APK 
LotteryOnline.apk: 签名前的APK 
然后按回车:会要求输入刚才设置的密码,输入后按回车就开始签名了。 

你可能感兴趣的:(使用proguard混淆打包APK keystore的创建)