type
status
date
slug
summary
tags
category
icon
password
简单APP的安卓逆向记录
一个App的算法分析
抓包
工具:Charels+Postern
data:image/s3,"s3://crabby-images/2f09f/2f09ff4c2fca310e772a97e7527bd04982a1fce4" alt="notion image"
这个就是我们抓到的
data:image/s3,"s3://crabby-images/a4074/a4074d0db3c2479fe845e9ab3ef8fe4a86102ff7" alt="notion image"
我们发现他经过了某种加密
data:image/s3,"s3://crabby-images/c3e76/c3e76e8c058cdef5e80780e2613c52feee4f148f" alt="notion image"
我们可以通过字符串"Encrypt”定位到加密的位置,我们可以关注我们这个包名所在的位置
data:image/s3,"s3://crabby-images/a280f/a280f0906045c91cf666eef96b596aa17fca6d5c" alt="notion image"
我们定位到函数之后,先看看是否可以hook到这个函数
data:image/s3,"s3://crabby-images/6a44d/6a44d86238397b046a9bb35c35810c89402a3eba" alt="notion image"
fridahook辅助算法分析
看看能不能hook到这个函数
data:image/s3,"s3://crabby-images/4725a/4725a50aece36329d4d735df4a1d0dd38b9a1d79" alt="notion image"
我们发现并没有什么用,那我们往上面找查找他的用例
data:image/s3,"s3://crabby-images/b34f5/b34f5f8d7e5e92b9911b85b2eb8469c327205774" alt="notion image"
data:image/s3,"s3://crabby-images/13076/13076074bf7a50cb5a4eb12322c710809092b4e9" alt="notion image"
我们尝试hook一下这个函数
data:image/s3,"s3://crabby-images/31e24/31e2403f040b4b769e638c4421ba7a9264422ce2" alt="notion image"
我们发现hook到了
data:image/s3,"s3://crabby-images/951b0/951b0174d3b242c900e69d9141fa5ddd62247309" alt="notion image"
这个时候我们可以主动调用这个加密函数,看是否跟我们抓包得到的内容相等
data:image/s3,"s3://crabby-images/281de/281de640f0122023c7286e75c1572f8dfee8efae" alt="notion image"
data:image/s3,"s3://crabby-images/45333/45333044fc4b02c8d52a589749611a34805b5e03" alt="notion image"
我们记录下来之后发现跟抓包内容大体一样但是缺少了sign值
data:image/s3,"s3://crabby-images/ee117/ee117aebf5b1aa8ca0d3ca465282864995161308" alt="notion image"
直接搜索sign值
data:image/s3,"s3://crabby-images/44c68/44c68a0d1ca2708e11ebf7f6a2adfe3cf096e867" alt="notion image"
直接调用md5函数
data:image/s3,"s3://crabby-images/48b0b/48b0b26e2036cd90ce5d04403af55c09304b23b8" alt="notion image"
data:image/s3,"s3://crabby-images/429da/429da66ddf229d1fb63e58dac8b4653b7781f500" alt="notion image"
发现是一模一样的,到这里我们算是了解了它所有的算法加密过程
data:image/s3,"s3://crabby-images/9950b/9950b4a8815a4f85bcc6c4f8d325fd55c203c950" alt="notion image"
data:image/s3,"s3://crabby-images/5a0b5/5a0b5017029b5d741268329da6265d86172ac04d" alt="notion image"
我们发现它把我们hook到的key的md5值作为DES的密钥,而我们的明文为之前我们获取的结构,接下来就是复现算法
算法复现
首先我们要获得sign的值
利用CryptoJS这个包
从我们记录下的sign的值的结构如下:
data:image/s3,"s3://crabby-images/fb0d3/fb0d3a6ed61ca9fb50bc3e3d71125e73a4f79238" alt="notion image"
因此我们需要构造一个函数去实现它
data:image/s3,"s3://crabby-images/dfd29/dfd2910570dc65264f5aea8026bbaad4ec0e52bf" alt="notion image"
经过比较发现是正确的
data:image/s3,"s3://crabby-images/573a1/573a1a081c2ec46893639f1d73de90e50550f12b" alt="notion image"
构造加密函数
data:image/s3,"s3://crabby-images/d4c61/d4c614d3f4fb08ee1bc67a350cd80f0b6b0d1d07" alt="notion image"
构造解密函数
data:image/s3,"s3://crabby-images/a3e07/a3e07cf13970e2b9d6254417a6fd33478ad23abf" alt="notion image"
协议复现
笔者选用的是python实现协议的复现
实现成功
data:image/s3,"s3://crabby-images/06b0e/06b0e339c100e69eca5742a985e564ba7829edab" alt="notion image"
🤗 总结归纳
本篇文章只是笔者在学习安卓逆向中的第一个实战,意在了解app逆向的基本流程和对hook的初步了解
📎 参考文章
有关学习或者复现上的问题,欢迎您在底部评论区留言,一起交流~
- Author:5m10v3
- URL:https://5m10v3.top/article/11f533f9-4e40-8085-a905-d30c6afc0291
- Copyright:All articles in this blog, except for special statements, adopt BY-NC-SA agreement. Please indicate the source!
Relate Posts