[网鼎杯 2020 青龙组]jocker

过程中借鉴博客

IDA出现"sp-analysis failed"和F5(反编译)失败-CSDN博客

[网鼎杯 2020 青龙组]jocker(详解)-CSDN博客

运行获得关键信息

我们分析函数的时候,这里有个报错

然后汇编是这样

有个 sp栈报错

这里我先谈谈我的理解,因为这道题的还有smc的成分,所以在之前的代码中,IDA看encry加密里面可能有return什么的,让栈报错啥的,让IDA分析错误,那么我们在SMC后,重新编译下就OK了

至于其他wp说那个改地址,我感觉没有必要,重新编译后就OK了

这个就是SMC

我们断在后面

然后在汇编中将函数重新编译就正常了

flag{d07abccf8a410c

解出来会少一部分

我们再对下面的finally函数进行重新编译(可能因为SMC的原因,一部分encry的代码干扰了finall让finally也G了)

从函数开始到所以红色的

重新编译就OK

但是这一段的逻辑很混乱

我也是看的其他人的wp才理解到思路------v3这五个字符,可能是和前面加密一样的操作,来得到flag,最后一个一定是},所以我们通过最后一个得到key,然后进行操作

脚本如下

python 复制代码
import string
a='hahahaha_do_you_find_me?'
b=[0x0000000E, 0x0000000D, 0x00000009, 0x00000006, 0x00000013, 0x00000005, 0x00000058, 0x00000056,
    0x0000003E, 0x00000006, 0x0000000C, 0x0000003C, 0x0000001F, 0x00000057, 0x00000014, 0x0000006B,
    0x00000057, 0x00000059, 0x0000000D, ]
flag=''
for i in range(len(b)):
    flag+=chr(b[i]^ord(a[i]))
print(flag)
c='%tp&:'
for i in range(len(b),len(a)):
    flag+=chr(ord(c[i-len(b)])^71)
print(flag)
for i in string.printable:
    if(ord(c[len(c)-1])^ord(i)==ord('}')):
        print(ord(i))
相关推荐
AI_RSER3 分钟前
第一篇:【Python-geemap教程(三)上】3D地形渲染与Landsat NDVI计算
开发语言·python·3d·信息可视化·遥感·gee
Johny_Zhao19 分钟前
阿里云平台健康检查巡检清单-运维篇
linux·网络安全·阿里云·信息安全·云计算·shell·系统运维
WSSWWWSSW26 分钟前
Python编程基础与实践:Python循环结构基础
开发语言·python
极客BIM工作室29 分钟前
深入理解C++中的Lazy Evaluation:延迟计算的艺术
开发语言·c++
im_AMBER43 分钟前
学习日志25 python
开发语言·python·学习
南棱笑笑生1 小时前
20250802让飞凌OK3576-C开发板在飞凌的Android14下【rk3576_u选项】适配NXP的WIFIBT模块88W8987A的蓝牙
c语言·开发语言
Blossom.1181 小时前
基于深度学习的医学图像分析:使用DeepLabv3+实现医学图像分割
人工智能·python·深度学习·yolo·目标检测·机器学习·迁移学习
吉凶以情迁2 小时前
window服务相关问题探索 go语言服务开发探索调试
linux·服务器·开发语言·网络·golang
22:30Plane-Moon2 小时前
Servlet作用域,监听器,JSP九大内置对象
java·开发语言·servlet
小白(猿)员2 小时前
JVM、JDK、JRE的区别
java·开发语言·jvm