ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Android~apk的混淆和加固,初级安卓开发面试题

2021-12-25 12:33:41  阅读:233  来源: 互联网

标签:dex 文件 面试题 混淆 安卓 apk 加固 打包


  1. 保留方法名

  2. 保留类名和方法名

-dontwarn retrofit2.**

-keep class retrofit2.** { *; }

-keepattributes Signature

-keepattributes Exceptions

-keep public class **.R$*{

public static final int *;

}

[

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享

]( )1.2 混淆为什么需要保留类名和方法名

原因有下面几种

  1. 如果是NDK开发,需要让C/C++可以通过JNI使用对应的java方法;

  2. 四大组件由于在清单文件中已经声明注册,不可以改变所以需要可以保留;

  3. R文件混淆会导致引用错误。

1.3 如何去除日志信息:

打开优化开关,使用proguard-android-optimize.txt。然后通过配置proguard将android.util.log类方法设置为无效代码,从而去除apk中打印日志的代码。

1.4 什么是加固

针对apk,加固是多维度的安全防护方案,包括反破解、反逆向、防篡改等,可以防止应用被各类常见破解工具逆向,安全性要远大于单纯的代码混淆。操作的对象是项目打包成的apk文件。

1.5 如何加固
  • 对抗反编译工具,通过让apk或dex文件无法正常通过反编译工具编译,导致编译工具异常或奔溃。如Apktool、baksmali、dex2jar、JEB等。通过考虑分析反编译工具源码原理,让反编译工具对我们的apk无效。

  • 对抗安卓模拟器,一般运行在安卓模拟器中的程序是处于逆向分析状态,我们可以在我们的代码中通过检测当前运行环境是否和安卓虚拟机类似,从而直接退出我们的程序。

检测安卓模拟器的方式有下属几种:

  1. 检测模拟器上面特有的几个文件;
  1. 检测模拟器默认的电话号码;
  1. 检测设备IDS是不是"0000000000";
  1. 检测imsi是不是"310260000000000";
  1. 检测手机上的一些硬件信息;
  1. 检测手机运营商等。
  • 对抗apk重打包。apk重打包是指先使用反编译工具得到smali代码,然后再由smali代码重新打包生成apk,最后重新签名才能运行。我们可以通过对签名的校验来放置apk被重新签名打包分析。

  • 如何对抗IDA Native层调试? 如果进程被IDA调试,/proc/pid/status文件中TracePid不等于0,可以利用这个条件检查我们的程序是否被IDA调试。

总结

为什么我们需要混淆?因为java字节码特性很容易反编译。对于加固,上架应用市场一般提供相关文档指导我们进行apk的渠道打包发布,这里不做展开我们先大概知道加固的一些原理。混淆的步骤:

  1. 修改gradle

release {

minifyEnabled true

shrinkResources true

proguardFiles getDefaultProguardFile(‘proguard-android.txt’), ‘proguard-rules.pro’

}

  1. 参考需要保留的类及方法,确定项目中哪些不能混淆的类

  2. 参考混淆模板,编写我们的混淆文件。

2. 加固

这里学习一下享学课堂的加固方案,属于学习笔记。可以参考这一篇文章比较详细:Android应用加固的简单实现方案。他在此基础上,使用Gradle集成到了项目中。

2.1 加固方案

加固

加固

APK逆向的一般流程:apk ->zip -> dex -> jar 源码

问题

  • dex文件可以随便拼凑吗?

  • 壳dex怎么来的?

  • 如何进行二次签名?(代码调用sdk中签名工具签名)

  • 如何运行新的apk(如何脱壳)?

壳dex作用,(lib模块生成aar文件 类似于 apk文件)

1.迷惑别人,暴露出去

2.壳用于加载加密的dex

粗粒度:dex文件的加密

细粒度:dex文件的里面的具体类加载

2.2 apk的打包流程

加壳是在原来APK基础上加一层保护壳,Dex文件修改了就需要重新打包,否则apk安装不了。所以我们需要知道apk的打包流程。

在这里插入图片描述dex文件按照一定规则来拼凑的,他的文件结构如下。

Dex文件

标签:dex,文件,面试题,混淆,安卓,apk,加固,打包
来源: https://blog.csdn.net/m0_64604893/article/details/122141644

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有