CTF003
data:image/s3,"s3://crabby-images/2edca/2edca5e8788e2cc402f995fd2597a3b854d6e6a1" alt=""
data:image/s3,"s3://crabby-images/9db37/9db3790c9b41265da3733884c482159d5f33df5a" alt="image-20230709144529782"
分析函数逻辑
打开入口函数后,可以发现把校验函数写在so库里了
data:image/s3,"s3://crabby-images/137f6/137f6816e8b460ea5da2644b238df8e4e0e6e39e" alt="image-20230709144547072"
IDA分析so库文件
那接下来用ida打开_native-lib.so_进行分析,文件打开之后可以直接搜索到这个函数,可以看到如果没有动态加载的话,java层映射到native层的本地函数命名特点Java+包名+函数名
data:image/s3,"s3://crabby-images/7a93e/7a93e9abd4d5145d909943643536bd4d43cb7274" alt="image-20230709144600683"
修复参数
这个函数解析的看起来比较乱,我们可以修复一下参数类型看会不会好点
- 在jadx里面看到只传递了一个参数,这里可以看到又三个参数,实际只有第三个参数_a3_才是我们传递的字符串参数,_a1_是JNIEnv* ,_a2_是JavaObject(表示Java层调用该JNI函数的对象的引用(即Java对象的指针))
修复完成之后我们来看一下这个函数
data:image/s3,"s3://crabby-images/ef733/ef733964c658111e3c6902363743c47b4a9a7483" alt="image-20230709144614920"
根据图中可知返回值来自于strcmp的比较结果,只有返回值为true也就是两个参数相等的情况下,验证才能通过。_strcmp_的两个参数都来自于_convertUnCharToStr_方法。这样的话可以尝试一下看能不能用_frida-trace_跟踪一下调用函数来查看这两个参数的值分别是什么
使用frida-trace来hook函数的传参
data:image/s3,"s3://crabby-images/595fe/595fefe29ec46287a87fcc7a6b7d1dd80afcca52" alt="image-20230709144627303"
这里我们可以看到成功的跟踪到了这两个函数,但是_strcmp()_触发的有点多,可能代码里面有很多比较的地方,
_convertUnCharToStr()_触发较少方便我们查看参数。
来查看一下跟踪到的函数:发现这里没有识别出来函数的参数可能是因为识别不准确造成的
data:image/s3,"s3://crabby-images/c4d26/c4d267c60c5d25fb1c62c2f1c7d48ce6be8aec5c" alt="image-20230709144651083"
根据函数原型编写hook脚本
void convertUnCharToStr(char* str, unsigned char* UnChar, int ucLen)
根据函数原型修改一下代码读取一下参数的值:获取so库函数的参数需要从内存中读取
data:image/s3,"s3://crabby-images/f8209/f820965b963f8ca430818ad7477c56ea7b8ad945" alt="image-20230709144715947"
修改完成之后保存,再点击验证按钮执行的时候看脚本打印结果
data:image/s3,"s3://crabby-images/f06b7/f06b7655da23d28253584979a8a692d764a954b8" alt="image-20230709144751559"
可以看到一串能读懂的字符串我们来试一下这个是不是就是flag
data:image/s3,"s3://crabby-images/d5971/d59715608e748de3bc6c39e519bb864b6df0c2f7" alt="image-20230709144803178"
输入之后点击验证按钮我们就能看到这个信封解封了
over~
- 标题: CTF003
- 作者: xiaoeryu
- 创建于 : 2023-07-09 14:43:10
- 更新于 : 2023-07-09 14:48:13
- 链接: https://github.com/xiaoeryu/2023/07/09/CTF003/
- 版权声明: 本文章采用 CC BY-NC-SA 4.0 进行许可。
评论