大家知道app 有安卓和ios
安卓是apk 现在基本上apk都是经过加密的 想动态脱壳没一定的技术是搞不定的
IOS是ipa 今天我主要讲的是这个
准备好反编译设备
1.一套越狱的ios手机 我的设备是iphone6 ios8.3 已越狱
2.一个mac系统 可以是vmware上的mac 黑苹果 或者直接用自己的mac电脑 我为了方便就用了黑苹果(如何搞黑苹果可以看我之前发表的博客)
给大家看下我的环境吧:
data:image/s3,"s3://crabby-images/19194/19194291535c7b1afe4308be5dcd719bdea80b5a" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
data:image/s3,"s3://crabby-images/d6d83/d6d8354110ac4fd01217728188fb31a9d6644b2d" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
准备反编译环境
1. 越狱手机上
1.1 Cydia上面安装 OpenSSH 安装成功后 可以remote到你的手机 默认的密码是 alpine
data:image/s3,"s3://crabby-images/91982/91982e39cf1941ab0c7661b797acdc6746658473" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
1.2 github上下载clutch然后放置在手机的 bin目录下(可以使用Itools工具)
data:image/s3,"s3://crabby-images/a9919/a9919c0ed85bd1251065971c577498c36fc4089d" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
解释一下这个工具是干什么的:如果app是直接从appstore下载的话 默认会被加密的 那么你用反编译工具IDA(下面会说到)的话就不行。得用这个工具解密生成一个ipa
2. mac机器上面准备好 LLDB Remote Debug 环境 (lldb是什么具体可以搜索Google)
2.1 配置Debug Server
从 /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/ DeviceSupport/7.0.3\ \(11B508\)/DeveloperDiskImage.dmg 获得debugserver 然后复制到桌面(中间的那个 DeviceSupport 可以根据具体路径替换)
data:image/s3,"s3://crabby-images/7cf00/7cf002c67588237420eb2fdc807ad473ec5fb27f" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
2.2 光有这个不行 还得弄下签名
创建一个 文件叫 Entitlements.plist 然后用 xcode打开进行编辑写入
data:image/s3,"s3://crabby-images/efcb3/efcb37dd3358db591c9c6266c236e6bd3cf5503c" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
输入命令 codesign -s - --entitlements entitlements.plist -f debugserver 之后 把这个 debugserver 传回 手机设备 的 /usr/bin/debugserver (可以使用Itools工具)
data:image/s3,"s3://crabby-images/d4805/d48059f68e9c60eb18ef2f5d8d7e2e6e09917f4f" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
3. windows系统上安装反编译利器IDA工具,大家可以百度搜破解版
data:image/s3,"s3://crabby-images/359a1/359a1b046fa9b66856055b5eff890b74c446ff59" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
反编译实验开始
在mac系统上 ssh连接 手机设备
data:image/s3,"s3://crabby-images/0af73/0af73bac4c4771dd69e9a367affe8fff42729653" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
如果你的app是从appstore上下载的那么请先用clutch解密 【我这里就举了一个Discord程序的例子】
1 用clutch -i 命理 找到你安装的app的编号
data:image/s3,"s3://crabby-images/01624/01624a9096dead051adfe0a9bcf1fb18ce6557be" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
2 用clutch -d 2命令进行解密操作
data:image/s3,"s3://crabby-images/d579a/d579a4573bbd10fd351d84103b8263e9e988b344" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
由于某头条我是从越狱版本Itools上下载的 本身就已经解密过了 所以不需要上面的操作
我直接用Itools导出ipa包
data:image/s3,"s3://crabby-images/617de/617ded462390bcb08c2f237f7ad449c9bdf2d6d3" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
打开 Fiddler 进行抓包分析(如何配置手机代理请自行百度了)
打开app的注册页面
data:image/s3,"s3://crabby-images/5226b/5226b0dd20d06e4a635d5b744a65ca1917f69a99" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
这里有一个获取验证码的图片的请求
data:image/s3,"s3://crabby-images/ba975/ba97590ce2ae1e0672b2565a6f7237493588a07c" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
请求的url里面有一个sign参数 一看就知道这个是md5加密
接下来我们就是要拿到这个md5是如何生成的
用IDA打开ipa包(第一次打开需要花点时间)
按SHift+F12打开 搜索String关键字 "sign"
data:image/s3,"s3://crabby-images/2d16d/2d16d533a121c8d72cadd6c1fd22365b82c39cd7" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
双击进入
data:image/s3,"s3://crabby-images/a7888/a788823a2e8e371ed729b7760f5bc732f9a94b22" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
继续双击进入 Function
data:image/s3,"s3://crabby-images/e52ab/e52abb237a9cbd755016532422a9677789411a22" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
按 F5
data:image/s3,"s3://crabby-images/74a48/74a48188d50f9a1e6816adbdcb8054a9f6e9230c" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
这里我们可以得知 加密的类叫 BFCrytor 里面有一个 MD5方法
在Function列表搜索一下 果然有
data:image/s3,"s3://crabby-images/fdc45/fdc451682cfdb0ab4468b7718ff2a83ad2b4bd5c" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
好了 已经成功找到了 加密md5的类和方法名称了
接下来开始最重要的步骤了 要根据 类和方法名称找到 程序运行的 内存地址 然后对这个内存地址进行下断点
1.把ipa包copy到mac系统里面 然后 用 Class-DumpXApp -H -A -S -oheaders/
dump出来的头文件里面标记了 IMP 的地址 输入到 header文件夹
在该文件夹搜索刚刚我们找到的类名称 BFCryptor 用Xcode打开
data:image/s3,"s3://crabby-images/1795c/1795ce80ca561e6e174ae8162f54045721260bf4" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
data:image/s3,"s3://crabby-images/ca353/ca353421fa6b27bdeab0e8f4ae618795cda371ce" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
记录下这个内存地址 0x0000000100241e30
lldb 挂载
用 px -a 命令找到 app 运行的 id
data:image/s3,"s3://crabby-images/b9403/b94033e531eb4ff0de482d0453d22966791ffe9e" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
然后用命令执行挂载 执行完后 发现app被卡主了 一切都静止了
data:image/s3,"s3://crabby-images/cf10d/cf10d4ac8b531387d27733605add8cc9b1e32514" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
再打开另外一个bash 执行本地命令
> lldb> platform select remote-ios> process connect connect://iOSIP:8888
过一会儿就会看到下面这个就代表挂载成功
data:image/s3,"s3://crabby-images/4ea1b/4ea1bf91277d026c26a7ca1fcf618bf21a8ad4fa" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
获取 ASLR 偏移量
data:image/s3,"s3://crabby-images/40da0/40da08d125d28041f2dbf7f844dda8aae2e67289" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
那么 断线的内存地址 的算法 就是 基址 + 偏移量
也就是md5 方法的内存地址 = 0x00000000000fc000 + 0x0000000100241e30
用下面的命令进行下断点
data:image/s3,"s3://crabby-images/99639/99639c3bf8a40f48a51fcde62c7a0da721620203" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
断点下完后 执行 c 命令 让 app 跑起来 触发一个网络请求 就会发现 断点停下来的
data:image/s3,"s3://crabby-images/7c847/7c847003f70acf7c3fe67dacb5ea5135bb3ca6e0" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
用 po 命令打印参数 发现 arg3就是我们md5加密前的数据
data:image/s3,"s3://crabby-images/b1051/b105151bde68f825553914c5f1a477e73af3f2d6" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
接下来 就写一个模拟请求实验一下
data:image/s3,"s3://crabby-images/42eb2/42eb24c3ed3e9ee4aff6b95c25453a6d2c0df08a" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
data:image/s3,"s3://crabby-images/09501/095018cddf2dc9b56c0ed781bee000ec80775687" alt="教你如何反编译app,拿到加密方式 教你如何反编译app,拿到加密方式"
请求成功了!!!!!
总结:
这篇文章给大家讲了 如何配置反编译环境
反编译一个app 拿到加密方式的一般步骤是怎样的。
md5的方式还是比较简单的,用rsa算法加密(例如国寿app,12306app等)的就比较难。但是方法都是一样的。
祝大家好运!