zoukankan      html  css  js  c++  java
  • android 混淆基本知识

    官网介绍:https://www.guardsquare.com/en/proguard/manual/introduction

    android 开发文档:https://developer.android.com/studio/build/shrink-code.html

    1.混淆的基本原理

    android平台的混淆原理简单来说就是把代码中原来有具体含义的包名,类名,变量名,方法名等名称全部替换成按顺序排列的无意义的英文字母a、b、c….这样代码结构没有变化,还可以运行得到一样的结果,并且就算代码被反编译出来,别人很难弄懂代码的架构和具体意思。

    2.混淆步骤

      混淆过程:

    • 压缩(Shrink):侦测并移除代码中无用的类、字段、方法、和特性(Attribute)。
    • 优化(OPtimize):对字节码进行优化,移除无用指令。
    • 混淆(Obfuscate):使用a、b、c、d这样简短而无意义的名称,对类、字段和方法进行重命名。
    • 预检(Preveirfy): 在java平台上对处理后的代码进行预检,确保加载的class文件是可执行的。。
    a.打开
    minifyEnabled  为true

    buildTypes {
    release {
    minifyEnabled true
    proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
    }
    }

    b.android studio 中自定义文件
    sdk中tool里面proguard-android.txt

    在文件 工程appproguard-rules.pro中自定义。
    不混淆 ScrollView类中自定义的public print函数
    -keepclassmembers class com.example.zcx.democoderjoy.ScrollViewActi {
    public *;
    }
    效果:增加之前反编译:

    家之后效果:

    发现增加了print函数,并没有被混淆。

    常见的参数:

    -keep 指定类和类成员(变量和方法)不被混淆。

    -keepclassmembers 指定类成员不被混淆(就是-keep的缩小版,不管类名了)。

    -keepclasseswithmembers 指定类和类成员不被混淆,前提是指定的类成员存在

    -keep

    -keep public class * extends android.support.v4.**

    -keepclassmembers 

    -keepclassmembers class * extends android.app.Activity{

    public void *(android.view.View);

    }

    c.每次构建时 ProGuard 都会输出下列文件:

    dump.txt
    说明 APK 中所有类文件的内部结构。
    mapping.txt
    提供原始与混淆过的类、方法和字段名称之间的转换。
    seeds.txt
    列出未进行混淆的类和成员。
    usage.txt
    列出从 APK 移除的代码。

    这些文件保存在 <module-name>/build/outputs/mapping/release/ 中

    3.混淆优缺点

    混淆的优点主要两个:1.优化删除无用代码,减少apk的体积。2.混淆代码让其反编译之后,无法理解具体内容。

    缺点:调试不方便(可以使用mapping.txt),测试不充分可能导致部分功能不能使用。

     

    4.通用使用下面这些通配符来匹配:

    1) :匹配任何原始类型,如 boolean 、 int 等,但不包括 void 

    2) ? :匹配一个任意字符,不包括句号;

    3) :匹配任意个任意字符,不包括句号;

    4) ** :匹配任意个任意字符,包括句号;

    5) *** :匹配任意类型,包括原始类型和非原始类型,数组类型和非数组类型;

    6) … :匹配任何数目个任何类型的参数。

     参考链接:http://www.chenglong.ren/2016/10/21/android%E4%B8%AD%E6%B7%B7%E6%B7%86%E6%8A%80%E6%9C%AF%E6%80%BB%E7%BB%93/

  • 相关阅读:
    SQL删除多表关联数据的三种方法
    如何防范SQL注入攻击
    非关系型数据库和关系型数据库有哪些区别?
    Asp.Net生命周期的详解
    ASP与ASP.NET区别
    COOKIE和SESSION有什么区别?
    关于SQL数据库中cross join 和inner join用法上的区别?
    Java-编程规范与代码风格
    TCP 连接建立与关闭(三次握手与四次挥手)
    OSI 七层模型
  • 原文地址:https://www.cnblogs.com/zCoderJoy/p/6985408.html
Copyright © 2011-2022 走看看