博客
关于我
Android混淆精炼详解+常用库混淆+通用混淆模板
阅读量:374 次
发布时间:2019-03-05

本文共 3636 字,大约阅读时间需要 12 分钟。

Android混淆文件详解:配置与实践指南

作为一名开发者,我最近在一个项目中遇到了一个棘手的问题:测试手机运行的应用功能正常,但在发布正式包后,上传功能失效。经过一番调试,发现问题出在混淆文件上。原来项目中使用的是开源项目带的混淆文件,而新增的上传功能使用了Gson进行处理,但未对混淆文件进行相应调整。Gson在使用时需要处理混淆文件,这让我深刻认识到混淆文件的重要性。今天就来一探究竟,搞懂混淆文件的配置与使用。


启用混淆文件

在Android Studio中启用混淆文件非常简单。Android Studio内置了ProGuard,这是一个强大的代码优化和混淆工具,支持通过Gradle构建工具轻松配置。具体步骤如下:

  • 打开工程根目录下的build.gradle文件。
  • 修改buildTypes配置,确保release类型的minifyEnabled属性设置为true
  • proguard-rules.pro文件中添加混淆规则。
  • buildTypes {    release {        minifyEnabled true        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'    }}

    ProGuard的作用

    ProGuard主要有以下三个功能:

  • 压缩(Shrinking):移除未被使用的类和成员,减小APK体积。
  • 优化(Optimization):在字节码级别进行优化,提升应用运行速度。
  • 混淆(Obfuscation):通过随机命名保护类和成员,增大反编译难度。
  • 默认情况下,这三项功能都启用。


    ProGuard生成的文件

    在完成混淆后,ProGuard会在build/outputs/mapping/release目录下生成四个重要文件:

  • dump.txt:列出混淆后的APK中所有class文件的内部结构。
  • mapping.txt:详细记录混淆前的java源码与混淆后的命名映射关系。
  • seeds.txt:列出被混淆的类和成员。
  • usage.txt:记录剥离的代码。
  • 特别注意mapping.txt文件,它包含了混淆规则的详细记录。如有心人可据此反推原始代码,因此务必妥善保护这个文件。


    混淆文件的配置

    混淆文件的配置可以分为几个方面:

    1. 通用配置

    • 代码混淆压缩比:建议设置为-optimizationpasses 5
    • 不使用大小写混合类名:避免混淆后的类名包含大小写,设置-dontusemixedcaseclassnames
    • 保留非公共库类:设置-dontskipnonpubliclibraryclasses
    • 避免预校验:Android不需要预校验,设置-dontpreverify
    • 忽略预警信息:设置-ignorewarnings
    • 优化算法过滤:使用谷歌推荐的算法,设置-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*

    2. 保护特定元素

    • 保留注解:设置-keepattributes *Annotation*
    • 保留泛型:设置-keepattributes Signature
    • 保留代码行号:设置-keepattributes SourceFile,LineNumberTable
    • 保留四大组件:保留ActivityApplicationServiceBroadcastReceiver等类,设置-keep public class * extends android.app.Activity等。
    • 保留native方法:设置-keepclasseswithmembernames class * { native <methods>; }

    3. 常用库的处理

    许多库和框架在使用时需要进行混淆配置。常见的有:

    • Gson:默认配置即可,但需注意实体类不应混淆。
    • Butterknife:保留注解和内部类,设置-keepattributes Butterknife, InnerClasses
    • SlidingMenu:保留所有成员和类,设置-keepclasseswithmembernames class com.slidingmenu.**

    注意:这些配置不是随意复制的,而需根据文档调整路径名和包名。

    4. 第三方SDK处理

    对于第三方SDK,如支付宝、友盟等,需遵循提供的文档配置混淆文件。例如,支付宝支付保留关键类,设置-keep public class com.alibaba支付.**

    5. 自定义规则

    在项目中使用了自定义功能,如自定义View,需在混淆文件中保留这些类。例如:

    -keep public class com.example.CustomView extends android.view.View {    *** get*();    void set*(***);    public 
    (android.content.Context); public
    (android.content.Context, android.util.AttributeSet); public
    (android.content.Context, android.util.AttributeSet, int);}

    混淆文件的模板

    以下是一个通用的混淆文件模板:

    # 代码混淆压缩比-optimizationpasses 5# 不使用大小写混合类名-dontusemixedcaseclassnames# 保留非公共库类-dontskipnonpubliclibraryclasses# 不进行预校验-dontpreverify# 忽略预警信息-ignorewarnings# 谷歌推荐算法-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*# 保护注解-keepattributes *Annotation*# 保留泛型-keepattributes Signature# 保留代码行号-keepattributes SourceFile,LineNumberTable# 允许访问有修饰符的类和成员-allowaccessmodification# 不进行类成员重包装# 保留四大组件及其子类-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.preference.Preference# 保留支持包下的所有类-keep class android.support.** {*}# 保留自定义接口实现-keep public class * implements com.example.Interface# 保留native方法-keepclasseswithmembernames class * { native 
    ; }

    混淆文件的注意事项

  • JNI方法:JNI方法不可混淆,需设置-keepclasseswithmembernames class * { native <methods>; }
  • 反射类:使用反射时,需保留反射类不被混淆。
  • Parcelable:保留Parcelable实现类的CREATOR字段。
  • WebView接口:保留JS接口方法,避免混淆。
  • 枚举类:保留values()valueOf()方法,设置-keepclassmembers enum * { public static **[] values(); public static ** valueOf(java.lang.String); }

  • 通过以上配置和实践技巧,你可以有效管理混淆文件,确保应用在反编译时的安全性和性能。记住,混淆文件的配置需要根据项目需求进行调整,不能一味照搬模板。

    转载地址:http://uqjg.baihongyu.com/

    你可能感兴趣的文章
    nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
    查看>>
    Nodejs异步回调的处理方法总结
    查看>>
    NodeJS报错 Fatal error: ENOSPC: System limit for number of file watchers reached, watch ‘...path...‘
    查看>>
    nodejs支持ssi实现include shtml页面
    查看>>
    Nodejs教程09:实现一个带接口请求的简单服务器
    查看>>
    nodejs服务端实现post请求
    查看>>
    nodejs框架,原理,组件,核心,跟npm和vue的关系
    查看>>
    Nodejs概览: 思维导图、核心技术、应用场景
    查看>>
    nodejs模块——fs模块
    查看>>
    Nodejs模块、自定义模块、CommonJs的概念和使用
    查看>>
    nodejs生成多层目录和生成文件的通用方法
    查看>>
    nodejs端口被占用原因及解决方案
    查看>>
    Nodejs简介以及Windows上安装Nodejs
    查看>>
    nodejs系列之express
    查看>>
    nodejs系列之Koa2
    查看>>
    Nodejs连接mysql
    查看>>
    nodejs连接mysql
    查看>>
    NodeJs连接Oracle数据库
    查看>>
    nodejs配置express服务器,运行自动打开浏览器
    查看>>
    NodeMCU教程 http请求获取Json中文乱码解决方案
    查看>>