zoukankan      html  css  js  c++  java
  • android应用程序的混淆打包

    android应用程序的混淆打包
    1 . 在工程文件project.properties中加入下proguard.config=proguard.cfg , 如下所示:

    target=android-8

    proguard.config=proguard.cfg

    Eclipse会通过此配置在工程目录生成proguard.cfg文件

     2 . 生成keystore (如已有可直接利用)

    按照下面的命令行 在D:Program FilesJavajdk1.6.0_07in>目录下,输入keytool -genkey -alias android.keystore -keyalg RSA -validity 100000 -keystore android.keystore

    参数意义:-validity主要是证书的有效期,写100000天;空格,退格键 都算密码。

    命令执行后会在D:Program FilesJavajdk1.6.0_07in>目录下生成 android.keystore文件。

     3. 在Eclipce的操作

    File -> Export -> Export Android Application -> Select project -> Using the existing keystore , and input password -> select the destination APK file 

     经过混淆后的源代码,原先的类名和方法名会被类似a,b,c。。。的字符所替换,混淆的原理其实也就是类名和方法名的映射。

    但4大组件并没有混淆(所有在清单文件定义的组件不能被混淆),因为系统需要通过清单文件来查找和运行应用程序。

     proguard.cfg 文件代码解读

    -optimizationpasses 5  ->设置混淆的压缩比率 0 ~ 7 

    -dontusemixedcaseclassnames -> Aa aA 

    -dontskipnonpubliclibraryclasses ->如果应用程序引入的有jar包,并且想混淆jar包里面的class 

    -dontpreverify 

    -verbose ->混淆后生产映射文件 map 类名->转化后类名的映射

     -optimizations !code/simplification/arithmetic,!field/*,!class/merging/*  ->混淆采用的算法.

     -keep public class * extends android.app.Activity   ->所有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>;   -> 所有native的方法不能去混淆. 

    }

     -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 {   -> aidl文件不能去混淆. 

      public static final android.os.Parcelable$Creator *;

    }

  • 相关阅读:
    TLS1.3 认证和秘钥建立握手环节的分析
    使用华为云+GitHub搭建自己的博客
    TLS1.3 握手协议的分析
    Formal Analysis of the TLS Handshake Protocol -----论文整理
    TLS1.3 握手过程特性的整理
    TLS1.3 PPT 整理
    SSL/TLS 握手协议简述
    TLS握手秘钥套件分析
    Scyther-Compromise 协议形式化安全分析如何改进协议
    HTTP 协议部分常识简介
  • 原文地址:https://www.cnblogs.com/wangxingliu/p/3512993.html
Copyright © 2011-2022 走看看