Andorid APK反逆向
Andorid APK反逆向解决方案---梆梆加固原理探寻
http://blog.csdn.net/androidsecurity/article/details/8892635
Android APK加壳技术方案【1】
http://blog.csdn.net/androidsecurity/article/details/8678399
Android APK加壳技术方案【2】
http://blog.csdn.net/androidsecurity/article/details/8809542
梆梆加固 官网
http://dev.bangcle.com
http://www.secneo.com/appProtect/
梆梆加固apk
下载一个apk上传到梆梆云端,获取其加固包
梆梆可以很准确的解析混淆过的apk文件(说明混淆对于保护文件的作用并不是那么大)
keywords:
dexguard 用法等;
android apk 反逆向
android 加壳
为什么这么多商业Android开发者不混淆代码?
- 领导、产品、项管在这方面没有意识,不重视。
- 单靠ProGuard是不够的, 随随便便就被反编译了,况且一些Activity,Service的名字不能被混淆,混淆后xml文件中相关的类找不到它们了。还有一些反射相关的也不能被混淆,等等…
- 混淆后增加了测试成本。
- 国内的安全意识普遍没有那么高。
其实自动打包时,大多数公司还是会用官方提供的Proguard的默认混淆的(个别公司除外)。蜻蜓FM也混淆了,用的就是Proguard 然而并没有什么卵用。
混淆想做到安全,还是需要自己做,或者购买一些第三方专业的混淆工具,比如:
- 国外的DexGuard,一年600多刀,效果不错。混淆后反编译出来的都是乱码,但这样成本并不是一两天时间,可能会遇到:
- 混淆后部分应用市场读却不到AndroidManifest.xml中的相关信息,审核失败的情况
- 还有比如有时对gradle打包支持不到位,需要特别写脚本支持混淆流程的
- 接入一些第三方的库混淆后会有问题等等要解决,
- 还需要经常升级混淆程序,所以总体还是会耗费不少时间的。
- 像微信连资源文件名都混淆,并且大部分东西都放在.so文件中,估计是自己做的,这个是需要一定精力的。
- 国内的没使用过,有一些什么梆梆加固,爱加密的,不知道混淆效果如何……
- 从安全角度
密码学里对“安全的”算法有一描述:即使攻击者知道了该加解密算法,在他们不知道密钥的情况下,使用算法的系统很难(没有绝对安全)被攻破。
所以混淆代码的作用只是增加了攻击者知道“系统”所使用的算法的难度。而安全本身在于“系统”所选择的算法以及对应“密钥”。(“系统”及“密钥”是个广义概念,可类比为移动app所使用的协议以及校验信息)
- 从盈利角度
如果app是工具类,混淆代码还是有必要的,否则第三方很轻松拿到代码改一改也可以上线了。
如果app是作为一个用户与服务提供者进行交互(信息交换)的终端之一,注意设计好双方的通信协议,并保护好核心代码。
ref: https://www.zhihu.com/question/37446729
Android APK加固技术方案调研
软件安全领域的攻防向来是道高一尺魔高一丈,攻防双方都处于不断的演变和进化过程中,因此软件加固技术需要长期持续的研究与投入。
目前成熟的第三方解决方案
1. 娜迦
针对Android平台下的APP被逆向分析,破解,植入木马病毒后,用户敏感信息泄露或者被钓鱼网站劫持,NAGA Android保护采用防止静态分析与防止动态调试全面防护的思路,在未保护程序运行的不同周期采取不同程度的加固措施,可以针对银行、基金、券商,电商等需在线支付领域及游戏领域,提供定制型APP安全解决方案。
主要实现:
- 类抽取:保护dex文件,防止静态分析及动态破解
- 代码加解密:保护so文件,防止静态破解
- 网络访问控制:保护so文件,拦截恶意广告,阻止注入型木马
- 敏感文件检测:保护so文件,防止静态调试
- 整体包裹:保护dex文件,防止静态破解
- 利用重定位清除ELF头:保护so文件,利用系统机制ELF头已经被系统清除,不兼容X86处理器
- 字符串表加密:保护so文件,防止静态破解
- 检查核心库:保护so文件,防止功能性数据库被劫持
- 检查调试器:保护so文件,防止动态调试
- Xposed检查:保护so文件,防止so文件,防止静态调试,防dump 防xposed脱壳神器对加固apk进行一键脱壳
- 防止跟踪:保护so文件,防止动态跟踪
- 强力清除ELF头:保护so文件,防止静态分析
- 中间码乱序:保护smali文件,dex保护,防止静态分析,不兼容Android5.0 ART模式
- 重定位加密壳段:保护so文件,对抗静态分析
- 壳完整性检查:保护so文件,防止对APP程序中的壳段进行修改、调试 兼容性100%
扩展阅读:娜迦社区
2. 爱加密
爱加密主要功能:
1. 漏洞分析:
- 文件检查:检查dex、res文件是否存在源代码、资源文件被窃取、替换等安全问题
- 漏洞扫描:扫描签名、XML文件是否存在安全漏洞、存在被注入、嵌入代码等风险。
- 后门检测:检测App是否存在被二次打包,然后植入后门程序或第三方代码等风险。
- 一键生成:一键生成App关于源码、文件、权限、关键字等方面的安全风险分析报告。
2. 加密服务:
- DEX加壳保护:DEX文件加壳保护对DEX文件进行加壳防护,防止被静态反编译工具破解获取源码。
- 内存防dump保护:防止通过使用内存dump方法对应用进行非法破解
- 资源文件保护:应用的资源文件被修改后将无法正常运行
- 防二次打包保护:保护应用在被非法二次打包后不能正常运行。
- 防调试器保护:防止通过使用调试器工具(例:zjdroid)对应用进行非法破解
- 多渠道打包:上传1个APK,通过选择android:name和填写android:value来实现对每一个渠道的包的生成和加密
- 漏洞分析服务:漏洞分析采用文件检查、漏洞扫描、后门检测等技术方向对APK进行静态分析并支持一键生成分析报告
- 渠道监测服务:监控国内400多个渠道市场入口,对应用的各渠道的下载量、版本信息、正盗版进行一站监控
- 签名工具:爱加密提供纯绿色签名工具,支持Windows、Linux和MAC系统,同时支持批量签名
- DEX专业加壳保护:本服务是对安卓DEX文件进行加壳保护,有效防止所有静态调试器对APK进行破解
- DEX专业加花保护:本服务对安卓DEX文件进行加入花指令(无效字节码)保护
- 资源文件指纹签名保护:对资源文件指纹签名进行验证保护,有效防止资源文件被篡改
- 高级防二次打包保护:本服务对APK进行防止二次打包保护,防止APK被使用非法手段修改替换文件后进行二次打包
- 高级防调试器保护:防止通过使用调试器工具(如:zjdroid、APK改之理、ida等)对应用进行非法破解
- 高级内存保护:本服务是对内存数据的专业高级保护,可防止内存调试,防止通过dump获取源码,防止内存修改
- 截屏防护:防止黑客通过截屏形式获取应用账号、应用密码、支付银行卡号、支付银行卡密码,支持安卓所有机型
- 本地数据文件保护:对APK应用的网络缓存数据、本地储存数据(提供SDK)进行深度保护
- 源码优化:1) 一键清除Log(开发日志)信息;2) 一键优化减少加密后增大的源用包大小
- 防止脚本:本服务爱加密提供防止脚本SDK,用户根据开发帮助文档进行二次开发,此保护项可有效防止游戏非法使用脚本
- 防止加速器:防止游戏使用加速器,破坏游戏公平(如:防八门神器和葫芦侠中的加速器功能)
- 防止模拟器运行:防止模拟器非法运行(可以防止运行在PC上的任何类型的android模拟器)
- 防止内购破解:防止游戏被内购破解(如:游戏内部有支付项,可以防止支付项相关内容被破解)
- SO文件保护:so文件专业保护,对so文件进行优化压缩、源码加密隐藏、防止调试器逆向分析
3. 渠道监测:
- 渠道数据监控
- 精准识别渠道正盗版
- 盗版APP详情分析
3. 梆梆加固
提供的移动应用保护服务:
- 防逆向保护:以加密代码的方式阻止反编译,从而防止被窃取代码和创意
- 防篡改保护:通过对app的完整性保护,防止app被篡改或者盗版
- 反调试保护:阻止应用运行中被动态注入,防止被外挂,木马偷窃账号密码,修改交易金额等
- 存储数据加密保护:更底层,跨文件格式的数据加密,防止应用数据被窃取
- 环境监测和保护:云监测设备环境,防止盗版应用,恶意应用的钓鱼攻击
扩展阅读:安全SDK下载
4. 360加固保
加固保为移动应用提供专业安全的保护,可防止应用被逆向分析、反编译、二次打包,防止嵌入各类病毒、广告等恶意代码,从源头保护数据安全和开发者利益,主要提供:
- 反篡改:通过签名校验保护,能有效避免应用被二次打包,杜绝盗版应用的产生
- 反窃取:对内存数据进行变换处理和动态跟踪,有效防止数据被获取和修改
- 反逆向:对代码进行加密压缩,可防止破解者还原真实代码逻辑,避免被复制
- 反调试:多重手段防止代码注入,可避免外挂、木马、窃取账号密码等行为
[总结]常见app漏洞及风险
静态破解:
通过工具apktool、dex2jar、jd-gui、DDMS、签名工具,可以对任何一个未加密应用进行静态破解,窃取源码。
二次打包
通过静态破解获取源码,嵌入恶意病毒、广告等行为再利用工具打包、签名,形成二次打包应用。
本地储存数据窃取
通过获取root权限,对手机中应用储存的数据进行窃取、编辑、转存等恶意行为,直接威胁用户隐私。
界面截取
通过adb shell命令或第三方软件获取root权限,在手机界面截取用户填写的隐私信息,随后进行恶意行为。
输入法攻击
通过对系统输入法攻击,从而对用户填写的隐私信息进行截获、转存等恶意操作,窃取敏感信息。
协议抓取
通过设置代理或使用第三方抓包工具,对应用发送与接收的数据包进行截获、重发、编辑、转存等恶意操作。
[总结]Android app加密保护核心概念
防内存窃取
防止通过gdb、gcore,从内存中截取dex文件,获取代码片段,从而反编译还原APK进行不法操作。
防动态跟踪
防止通过ptrace调试进程,跟踪、拦截、修改正在运行的应用,进行动态注入,保护程序运行安全。
防逆向分析
防止通过APKTool、IDA Pro等反编译工具破解DEX文件,从而获取APK源代码,保护代码层安全。
防恶意篡改
校验APK完整性,自动终止运行被篡改的APK,二次打包后应用都无法使用,杜绝盗版应用的出现。
存储数据加密保护
更底层,跨文件格式的数据加密,防止应用数据被窃取。
[我们的措施]Android程序反破解技术
对抗反编译
对抗反编译是指apk文件无法通过反编译工具(例如ApkTool,BakSmali,dex2jar等)对其进行反编译,或者反编译后无法得到软件正确的反汇编代码。
基本思路是寻找反编译工具在处理apk或者dex文件时的缺陷,然后在自己的代码中加以利用,让反编译工具在处理我们apk文件的时候抛出异常或者反编译失败,有两种方法可以找到反编译工具的缺陷:
- 阅读反编译工具的源码
- 压力测试
对抗静态分析
反编译工具一直在改进,因此即使你在版本2.1发现它的缺陷并加以利用,使反编译你的apk失败,但很可能在版本2.2就把这个缺陷解决了,因此,不要指望反编译工具永远无法反编译你的apk,我们还需要使用其他方法来防止apk被破解:
- 代码混淆技术,ProGuard提供了压缩,混淆,优化Java代码和(Shrinking),混淆(Obfuscation),优化(Optimition)Java代码和反混淆栈跟踪(ReTrace)的功能。
- NDK保护:逆向NDK程序的汇编代码比逆向Java代码枯燥和困难很多,同时使用C++也可以对敏感字符串和代码进行加密。
- 外壳保护:针对NDK编写的Native代码。
对抗动态调试
- 检测调试器:动态调试使用调试器来挂钩apk,获取apk运行时的数据,因此,我们可以在apk中加入检测调试器的代码,当检测到apk被调试器连接时,终止apk的运行。
- 检测模拟器:apk发布后,如果发现其运行在模拟器中,很有可能是有人试图破解或者分析它,因此这时我们也要终止apk的运行。
防止重编译
- 检查APK的签名
- 校验APK的完整性
- 校验classes.dex文件的完整性
参考资料
Andorid APK反逆向的更多相关文章
- Andorid APK反逆向解决方案---梆梆加固原理探寻
本文章由Jack_Jia编写,转载请注明出处. 文章链接:http://blog.csdn.net/jiazhijun/article/details/8892635 作者:Jack_Jia ...
- android逆向基础:apk 反编译 重打包 重签名
apk 反编译大家都比较熟悉,这里只做一个笔记. 1 反编译 apk apktool d perfect.apk 这样就把资源文件解压缩了, classes.dex 也反编译成了 smali 文件 2 ...
- [Android逆向]APK反编译与回编译
一.先查壳,再反编译看验证首先打开.apk文件==>反编译apk(dex/配置文件/资源文件(apk反编译失败)>修改关键文件实现自己的目的>重新打包签名(无法重新打包)==> ...
- Android apk反编译基础(apktoos)图文教程
本文主要介绍了Android apk反编译基础,使用的工具是apktoos,我们将用图文的方式说明apktoos工具的使用方式,你可以参考这个方法反编译其它APK试试看了 很久有写过一个广工图书馆主页 ...
- Android反编译,apk反编译技术总结
1.谷歌提供的工具:android-classyshark 下载地址:https://github.com/google/android-classyshark/releases,下载下来之后是一个可 ...
- apk反编译工具
反编译工具: apktool:资源文件获取,可以提取出图片文件和布局文件进行使用查看 dex2jar:将apk反编译成Java源码(classes.dex转化成jar文件) jd-gui:查看APK中 ...
- apk 反编译
http://blog.csdn.net/vipzjyno1/article/details/21039349/ [置顶] Android APK反编译就这么简单 详解(附图) 标签: android ...
- apk反编译
在学习Android开发的过程你,你往往会去借鉴别人的应用是怎么开发的,那些漂亮的动画和精致的布局可能会让你爱不释手,作为一个开发者,你可能会很想知道这些效果界面是怎么去实现的,这时,你便可以对改应用 ...
- JAVA_Android APK反编译就这么简单 详解(附图)
在学习Android开发的过程你,你往往会去借鉴别人的应用是怎么开发的,那些漂亮的动画和精致的布局可能会让你爱不释手,作为一个开发者,你可能会很想知道这些效果界面是怎么去实现的,这时,你便可以对改应用 ...
随机推荐
- 在windows 下使用git
首先安装好在windows下的linux模拟交互器 这里我选择的是cygwin 这里我是参考:http://book.51cto.com/art/201107/278731.htm 这里还要注意我这里 ...
- js闭包理解
js闭包的作用是使函数外可以访问函数内部的变量,是通过 在函数内部 定义 访问函数内变量 的函数实现的,内部的一个函数产生一个闭包 function a() { var i=0; return fun ...
- js判断鼠标位置是否在某个div中
div的onmouseout事件让div消失时,会出现这样的情况,就是当鼠标移至div中的其它内容时,此时也判定为离开div,会触发 onmouseout事件,这样div中的内容就不能操作了.解决的办 ...
- C# 字符串的截取和替换
1.取字符串的前n个字符 (1)string str1=str.Substring(0,n); (2)string str1=str.Remove(i,str.Length-n); 2.去掉字符串的前 ...
- ORACLE【1】:触发器详解
转自:http://blog.csdn.net/indexman/article/details/8023740 ORACLE PL/SQL编程之八: 把触发器说透 本篇主要内容如下: 8.1 触发器 ...
- Oracle操作数据库oracleHelper
1 Oracle OracleHelper //============================================================================ ...
- Makefile自动生成工具-----autotools的使用(详细)
相信每个学习Linux的人都知道Makefile,这是一个很有用的东西,但是编写它是比较复杂,今天介绍一个它的自动生成工具,autotools的使用.很多GNULinux的的软件都是用它生成Makef ...
- C# 操作Word 中的OLE——插入、编辑、读取 OLE
概述 OLE,Object Linking and Embedding,即对象连接与嵌入.我们在设计程序时,OLE可以用来创建复合文档,把文字.声音.图像.表格.应用程序等类型的信息组合在一起,在Wo ...
- 第一部分之简单字符串SDS(第二章)
一,什么是SDS? 1.引出SDSC字符串:c语言中,用空字符结尾的字符数组表示字符串简单动态字符串(SDS):Redis中,用SDS来表示字符串.在Redis中,包含字符串值的键值对在底层都是由SD ...
- JavaScript基础三
1.10 关于DOM的事件操作 1.10.1 JavaScript的组成 JavaScript基础分为三个部分: ECMAScript:JavaScript的语法标准.包括变量.表达式.运算符.函数. ...