type
status
date
slug
summary
tags
category
icon
password
关于2024CISCN的题解
asm_re
直接手撕汇编
data:image/s3,"s3://crabby-images/b745d/b745d90f2650bf425ebdeba0d7e76a0914c4d8a8" alt="notion image"
exp
androidso_re
data:image/s3,"s3://crabby-images/47a53/47a53625361fc436fb5fa20c4df629f106a11054" alt="notion image"
flag的加密在inspect这个类里面
经过了DES(CBC模式)加密+base64加密
那么我们需要得到DES加密的IV和key
在libSecret_entrance.so里面
data:image/s3,"s3://crabby-images/4b17e/4b17e49cb41b9da256f4d585d17b4ef79289b1f8" alt="notion image"
分别在getiv和getkey里面把a1的类型变一下改成JNIEnv*
data:image/s3,"s3://crabby-images/946f4/946f48867f6976a708baee93c2e9417f16383f68" alt="notion image"
data:image/s3,"s3://crabby-images/dc151/dc1519408600ee970500b2472a8d7bb2c1eb3391" alt="notion image"
然后我们直接利用jnitrace
data:image/s3,"s3://crabby-images/e8c41/e8c41ae6142d6506f81055caf933c5adec2b3b6b" alt="notion image"
data:image/s3,"s3://crabby-images/56270/56270c3c7dc3c1144bbb27afac00cc5e5fb2fcd4" alt="notion image"
data:image/s3,"s3://crabby-images/e8e27/e8e27396a84b06db91fc2dbaf51af54b5e3e7676" alt="notion image"
whereThel1b
出题人自己编写的动态链接库
data:image/s3,"s3://crabby-images/785bd/785bd53e4965405d8e3c40ac9cd1c0da061d903f" alt="notion image"
真正对明文进行处理的函数时whereThelib这个库里面的trytry函数
我们可以先搜索init,发现有一个PyInit_whereThel1b这个函数
data:image/s3,"s3://crabby-images/f0ca1/f0ca1818a0e85cd8a59bd409c36a0e742659d927" alt="notion image"
然后我们就可以找到初始化这些模块的地方__pyx_moduledef
data:image/s3,"s3://crabby-images/da470/da4702810be47b5d56b6c294a14c30df2e5a2332" alt="notion image"
这里定义了一个随机数种子
然后后面又调用了whereistheflag1
data:image/s3,"s3://crabby-images/a9845/a98455f64d0b9123499dc8acafb95a61902e6e6b" alt="notion image"
说明对字符的处理在whereistheflag1里面
在whereistheflag1里面先调用了一个base64,说明先进行了base64加密
data:image/s3,"s3://crabby-images/3398c/3398cfe87d65d17c8987da1ecd72ea0567c1db2f" alt="notion image"
还是生成一个随机数,生成的范围时是(0,len(arr))
data:image/s3,"s3://crabby-images/ff023/ff02392ed1f1cb5485f719ec94833884fafb0c56" alt="notion image"
data:image/s3,"s3://crabby-images/a8d74/a8d74a868a843ea549cec10aab3112b6cbf5be0f" alt="notion image"
这里还调用了一下xor
data:image/s3,"s3://crabby-images/1f900/1f90065d7d82577e58ebedd23d37b2c208f0a962" alt="notion image"
这里整理一下加密的逻辑
由于随机数种子的参数我们不知道
gdb_debug
加密逻辑非常清楚
有三处异或
在生成的随机数那里,有一个办法
在它调用rand这个函数之后,后面下一个条件断点
data:image/s3,"s3://crabby-images/482ff/482fffab03e01e712c03908316c6b0253905448c" alt="notion image"
我们需要下三处条件断点,然后得出三处生成的随机数数组
data:image/s3,"s3://crabby-images/42dde/42dded7b48536fdf57966ac6b6dff48360bd1dc5" alt="notion image"
rust_baby
首先我们要先找到这个函数
sub_7FF7B37F298A
这个函数相当于就是我们的主函数
data:image/s3,"s3://crabby-images/e77f2/e77f2ad228d27579d04ba5d29b68e079d8e3ef09" alt="notion image"
然后我们把memcpy的内容放到cyberchef里面解密,发现它一个字典的格式,这里面的信息对我们后面有用
这个函数就是输入函数
data:image/s3,"s3://crabby-images/557b3/557b39d94ffccce54ac6a8900264925cc182cf29" alt="notion image"
我们注意到后面只处理八个字符,所以我就先输入8个字符
我们直接下个硬件断点,然后我们可以跟踪对字符串的处理
data:image/s3,"s3://crabby-images/9b5bc/9b5bc0a2428f2a7cb4b535ec0830b259be67c5ee" alt="notion image"
由于这里的加密函数太复杂了,我们直接黑盒分析
我们可以得到这个规律,后面还有个异或操作
后面还有一个异或操作
data:image/s3,"s3://crabby-images/7e0e8/7e0e817a8909917131616e6b92fd704615f185bc" alt="notion image"
然后我们可以在这里提取出来我们需要异或的数值,但是我们怎么提取出真正的密钥呢,我们可以看到v91那里一共有104个字节,我们可以把这里全部设置成0
然后在后面可以提取出密钥,由于中间全部进行了base64加密操作,base64解密之后的就是真正的密钥
data:image/s3,"s3://crabby-images/e1b12/e1b125c5753d25086cff0a776ee539e0f9bbe9c3" alt="notion image"
GoReverse
程序分析
这里借鉴的思路是panda0s师傅的思路
data:image/s3,"s3://crabby-images/483c4/483c454f0cb7e3e3cef5b92719712a1deae3785c" alt="notion image"
发现没有符号表,我们可以先恢复一下符号表
https://github.com/0xjiayu/go_parser
克隆仓库,IDA加载go_parser.py即可,不需要把脚本放到plugin里面
data:image/s3,"s3://crabby-images/0f99c/0f99c47c4dfa7b65c515df0422f218ce87c202c4" alt="notion image"
初始化在runtime_main里面,然后我们的主函数在main__B2bUPq_Execute里面
里面一共有两个反调试的地方
data:image/s3,"s3://crabby-images/b5c41/b5c416a83820ac94f4157c345f2cc79925f614f4" alt="notion image"
在调用这个runtime_systemstack之后就会退出,我们可以把这个nop掉
data:image/s3,"s3://crabby-images/c420d/c420daa49f310892fb0cd207db82a9e5d28f2217" alt="notion image"
第二个反调试就很明显了,在地址0x004D64A0 这里
把他patch掉就行了
data:image/s3,"s3://crabby-images/46ec1/46ec16afe179408615db92ea28a788cb88a93e39" alt="notion image"
后面的zQyveE为xxtea加密,我们可以把ToUint32s复制下来
data:image/s3,"s3://crabby-images/ded56/ded56740cad0ac2859584b5a889ad231e9baab27" alt="notion image"
我们可以发现xxtea进行了魔改,魔改的地方为MX和delta
然后我们可以在以下几个地方设置断点
data:image/s3,"s3://crabby-images/33d50/33d50269a0284bc8b167199fae5184b8831d5e48" alt="notion image"
data:image/s3,"s3://crabby-images/8ad55/8ad55c4888e4480050797b85cf8b5a754d7e7678" alt="notion image"
然后我们可以先在进行异或操作之前下个断点
data:image/s3,"s3://crabby-images/41076/41076d2376c0cf600368687627ee842e7e76a44c" alt="notion image"
因为我是之前先异或了,所以再异或一下就回去了,这样便于我们更好分析
以下是我们异或的值
data:image/s3,"s3://crabby-images/bd13c/bd13cfa090b8e381a8a7f12e8ab8f21f1e2133d2" alt="notion image"
我们经过xxtea加密之后我们看一下它的返回值
data:image/s3,"s3://crabby-images/5d3b8/5d3b8b115d374e6c22ed8129c97ecc402a5ad93a" alt="notion image"
一共十六个字节,很明显是我们的输入之后的加密结果,但是我们便于分析统一变成11,这个时候我们就可以直接按F9
跳到了
data:image/s3,"s3://crabby-images/e6789/e6789142290967d8fd83461423c7c52b438125e4" alt="notion image"
然后这个时候我们可以得到SM4的密钥
继续往下面调
这是生成的随机数
data:image/s3,"s3://crabby-images/46ba2/46ba2aee069dd577422db6a12fb9e4e0cacb5867" alt="notion image"
我们统一把它设成22
再继续往下面调,一直到了
然后我们在rsi寄存器得到了我们一开始经过xxtea加密的密文
这个时候要和sm4生成的密文(CTR模式)进行异或
但是这个iv是随机生成的(后面会解释这个怎么得到)
继续往下面调我们可以到到aes的密钥
data:image/s3,"s3://crabby-images/2d86e/2d86e2b5ea1552012739e04bcc34ec325dd37c0a" alt="notion image"
再往下面走,我们可以得到aes的iv是key的前16位
我们在最后retn这里下个断点,我们把前16位的全都替换成33,最后在Linux里面会输出一段base32的字符串
data:image/s3,"s3://crabby-images/1ca3f/1ca3fe0539f7ebf8f5f359d4600c5c99a81a4aa3" alt="notion image"
data:image/s3,"s3://crabby-images/57d2d/57d2d9f1e70ed5ca05c7bf507a48a8430a844b5b" alt="notion image"
data:image/s3,"s3://crabby-images/9b7fe/9b7fe34dc593ff9d410e5c6d537da8e4b1d8cf47" alt="notion image"
就是我们最后输入的33,那么说明我们在经过base32和aes解密之后,得到的前16个字节就是sm4随机生成的iv
逆向分析
这里为了复现我直接借用了其它师傅在比赛中得到的flag
data:image/s3,"s3://crabby-images/3841d/3841dc5cdf04a11fb68c0ac95df4c4723c4a9ab1" alt="notion image"
根据flag长度为40或42可知counter还需要分别+1和+2,总共3*16bytes
data:image/s3,"s3://crabby-images/82424/82424c1744a79e176a42a6f20e3794401f786f14" alt="notion image"
我们将SM4加密的密文与AES解出来的明文的从第16位开始进行异或,解出来的就是xxtea的密文
之后进行xxtea加密
data:image/s3,"s3://crabby-images/f7a0d/f7a0d49fa2ea30f6ce5780c711c86e0200fad9a5" alt="notion image"
有关复现上的问题,欢迎您在底部评论区留言,一起交流~
- Author:5m10v3
- URL:https://5m10v3.top/article/6c54e1cb-35a0-46fa-8874-83cc331610b3
- Copyright:All articles in this blog, except for special statements, adopt BY-NC-SA agreement. Please indicate the source!
Relate Posts