type
status
date
slug
summary
tags
category
icon
password
以下为附件链接,供各位师傅下载练习
https://wwb.lanzout.com/i7mkm21aeegd
趁热打铁,前一阵子打国赛遇到了cpython的题,但是国赛那道cpython和这个相比简直就是”关公面前耍大刀“。
在此也非常感谢z221x师傅的博客
为我提供了一些很好的思路
Noval_cpython
我们可以先用help函数看一下有没有什么比较有用的信息
这里注意一下,它是用python3.10直接编译的,我调了很多遍,发现如果跟版本不一样的话会导致导入不了这个模块
接下来我们用help查看一下,可以得到很多有用的信息
data:image/s3,"s3://crabby-images/401f3/401f3382a61b1b9adf84455ff97db6e0987d115c" alt="notion image"
我们注意到了check和encrypt函数,在main.py中它使用的就是check()函数
data:image/s3,"s3://crabby-images/1444b/1444b43eb17a6b2e4f40e3c6fc2bba980038814e" alt="notion image"
然后我们可以注意到DATA那里有很多可疑的数据,我们先继续进行分析
首先第一步还是找到模块处理的地方
data:image/s3,"s3://crabby-images/8e0ee/8e0ee5bd158dc23a0d71d022c2dd6868466ca168" alt="notion image"
我们要从check_secret模块开始看
data:image/s3,"s3://crabby-images/b0343/b0343ca6df8fb7d8c51157b900da5ce1baed6c60" alt="notion image"
我们发现里面有很多对象,这让我想到之前学习驱动的时候,“驱动之内一切皆对象”,其实cpython在创建模块也需要很多对象
data:image/s3,"s3://crabby-images/0d7e6/0d7e66c096ec1cc83ca39af264c52b3f0363a7cf" alt="notion image"
data:image/s3,"s3://crabby-images/f2db3/f2db3146a6832a290e2e03626a948d5750907fa3" alt="notion image"
我们发现这里创建了很多对象,这里的操作相当于
这里是密文的初始化
data:image/s3,"s3://crabby-images/70271/70271d5e1c63def70f38cc4cc22e604fc512d90c" alt="notion image"
但是我们发现这个跟上面的help的情况不太一样,没有关系我们继续往下面看
这里重新打包了很多东西
data:image/s3,"s3://crabby-images/a16a7/a16a72fea9d4ac9b14fac7f6a9e59b71c82b7974" alt="notion image"
但是我们在伪代码层面看不出来它的逻辑
汇编层面:
data:image/s3,"s3://crabby-images/0c329/0c32908f931569e59c12e738f4f8552b2e0cff7d" alt="notion image"
我们发现它是定义algorithm1,algorithm2,algorithm3.......这些函数
data:image/s3,"s3://crabby-images/e2af3/e2af398eed61e31c6c3d523a2cff70d6b1fe19c3" alt="notion image"
然后最后的时候还有个加密函数,这个加密函数有七个参数,我们发现有一个delta的参数,在这里先猜测它可能是tea加密
继续往下面分析
这里为定义一个xixi变量
data:image/s3,"s3://crabby-images/bcad9/bcad9c2e66b01cb8b2dba7fbf9376298a0dc05a2" alt="notion image"
这里我们发现定义了一个sbox变量
data:image/s3,"s3://crabby-images/2c3d4/2c3d4f07a8e755251467e04b731fd160c8b96fc2" alt="notion image"
这里定义haha这个变量
data:image/s3,"s3://crabby-images/a7287/a728783a975c9b1e944ddb051e6f40e0ddd0a839" alt="notion image"
再往下面就是定义了打包的函数模块
这里就是真正定义密文的地方
data:image/s3,"s3://crabby-images/f8271/f82713544913acd53871c53ea1e80ca239afd97e" alt="notion image"
data:image/s3,"s3://crabby-images/2fc60/2fc60717f03f3301784ab1eede5d8480abbe4d5e" alt="notion image"
data:image/s3,"s3://crabby-images/36635/366350393628c8ca055bc4ae680ae672db6eee58" alt="notion image"
data:image/s3,"s3://crabby-images/9bad0/9bad0d2e2c3ce7198237fa1ba80f896942029da1" alt="notion image"
data:image/s3,"s3://crabby-images/65071/650710499f3d7c4cf655d11691e822fda63c819a" alt="notion image"
data:image/s3,"s3://crabby-images/baac4/baac48e8dbcd12e6975013f58ebfc4b6c9a76ac8" alt="notion image"
data:image/s3,"s3://crabby-images/c0648/c06484a3a21775cbb7b817c609b969c80fd7152c" alt="notion image"
data:image/s3,"s3://crabby-images/d2fa9/d2fa9d7242cc0932bc6a9b503b2631d183e8116b" alt="notion image"
data:image/s3,"s3://crabby-images/0cc98/0cc9841967cdbefa35924be0ad48e8a3baf2f0ca" alt="notion image"
总结一下上面八个函数以及前面打包函数的时候的两个参数
这里定义一个map函数
data:image/s3,"s3://crabby-images/694c5/694c5b74ff96ecb681d5959c79a557f447357248" alt="notion image"
后面就是定义encrypt函数,struct函数和check函数
data:image/s3,"s3://crabby-images/5e75e/5e75ec95a287de8e25b8b4aa64c3c8244fee6bb9" alt="notion image"
至此我们对于check_secret这个模块分析完了,这个模块全都是初始化的一些东西,然而我们在main.py调用的是check函数,接下来我们分析check函数
我们从上往下进行分析
发现这里调用了range函数
data:image/s3,"s3://crabby-images/2ed5f/2ed5fc2fd6686ae6d26c433493ee7fce2c483105" alt="notion image"
然后这里调用了s_box
data:image/s3,"s3://crabby-images/cf4c7/cf4c78a61c925f789a98fe8e0b54f2b9ad7ffa6c" alt="notion image"
梳理一下逻辑
实现了一个替换的功能
下面实现了一个struct函数
data:image/s3,"s3://crabby-images/3dc5a/3dc5a442402a8c0ce7a4339eed7ab2a4bbe3c1cd" alt="notion image"
data:image/s3,"s3://crabby-images/19f7e/19f7eebd8e375ded9465c5cc406de9d1a4ba44a3" alt="notion image"
data:image/s3,"s3://crabby-images/8f0a6/8f0a6de29441c2b558f8ff90e36dd1fade868d4a" alt="notion image"
然后下面开始加密
data:image/s3,"s3://crabby-images/1176e/1176e76bf487285f524b39c104430fa6e40ffaed" alt="notion image"
发现它还调用了下面的xixi,再往下分析
这里有个+2操作
data:image/s3,"s3://crabby-images/af3fa/af3fa2a9c235aa7f31d80f86dbd5a9088c42c6fb" alt="notion image"
后面又调用了一次加密函数,但是调用的是haha
data:image/s3,"s3://crabby-images/5efcf/5efcfa3b7ed2816c5974c0c52a5f05ad1a8fd79a" alt="notion image"
然后后面还有一个+2操作,但是到这里我们还无法确认它真正的加密逻辑是什么,然后我们去看encrypt函数
真正的加密在_pyx_pf_12check_secret_16encrypt里面
现在开始才是真正的逆向🈚,一共有5000多行,逆呗谁能逆过你啊
我们可以看到光定义变量都有500多行了
data:image/s3,"s3://crabby-images/ccbee/ccbee13a6e7ee216436985b829a969f4e46d4e94" alt="notion image"
我们发现这个加密函数有两个参数
data:image/s3,"s3://crabby-images/67089/67089c76eca86981c064b6d4b8afff80199e4192" alt="notion image"
其实我们还可以大胆写一下那个加密的逻辑
看起来很像tea加密
这里定义了一个uint32的变量
data:image/s3,"s3://crabby-images/747cb/747cba3f0a222d61c4475a935ab0d1a6003d484c" alt="notion image"
从上往下分析,我们发现还定义了另一个uint32的变量
然后我们有注意到了一个变量
data:image/s3,"s3://crabby-images/9864d/9864d7d1a8f7d6a50229d06fb1aa0ba00377f14b" alt="notion image"
它只有两处引用,可以猜测一下它经过了32次循环
data:image/s3,"s3://crabby-images/4c4c3/4c4c3d26768c121fe99a24909373cc7a5f0ea911" alt="notion image"
data:image/s3,"s3://crabby-images/7f959/7f959615e9803570d2abc6c1e94669ff3f07aacb" alt="notion image"
data:image/s3,"s3://crabby-images/e3340/e3340d49464cc9ad9b3878b73ebb095a3cc090e9" alt="notion image"
data:image/s3,"s3://crabby-images/1ceb4/1ceb4579e68481b6265af5ec753a7d51424a78e8" alt="notion image"
..........................后面的图很多,但是我们发现它经历了好多次重复的操作,然后还调用了大量的map
梳理一下
到这里我们可以确定这就是个tea加密
然后Arr3stY0u战队的师傅们提供了另一个思路
因为这个动态链接库是已经打包好的,所以我们可以直接调用里面的函数然后,再打印出来他们的操作(相当于就是hook操作)
然后我们就可以得到加密的过程
data:image/s3,"s3://crabby-images/814be/814be6e9119d05cbd1e28f125ff97fc2352a8d84" alt="notion image"
exp
有关Notion安装或者使用上的问题,欢迎您在底部评论区留言,一起交流~
- Author:5m10v3
- URL:https://5m10v3.top/article/22c68850-8b27-4ee6-9231-704533b36c6d
- Copyright:All articles in this blog, except for special statements, adopt BY-NC-SA agreement. Please indicate the source!
Relate Posts