当前位置: 首页 > article >正文

攻防世界 reverse题GFSJ0810-【crazy】

1.工具exeinfope、IDA Pro (64-bit)、thonny2.解题下载附件后我们先在exeinfope里查壳如下我们发现是64位无壳文件然后我们把它放到IDA Pro (64-bit)里分析我们点击F5先查看伪代码如下代码int __fastcall main(int argc, const char **argv, const char **envp) { __int64 v3; // rax __int64 v4; // rax __int64 v5; // rax __int64 v6; // rax __int64 v7; // rax __int64 v8; // rax __int64 v9; // rax __int64 v10; // rax __int64 v11; // rax __int64 v12; // rax __int64 v13; // rax __int64 v14; // rax __int64 v15; // rax __int64 v16; // rax char v18[32]; // [rsp10h] [rbp-130h] BYREF char v19[32]; // [rsp30h] [rbp-110h] BYREF char v20[32]; // [rsp50h] [rbp-F0h] BYREF char v21[32]; // [rsp70h] [rbp-D0h] BYREF char v22[32]; // [rsp90h] [rbp-B0h] BYREF char v23[120]; // [rspB0h] [rbp-90h] BYREF unsigned __int64 v24; // [rsp128h] [rbp-18h] v24 __readfsqword(0x28u); std::string::basic_string(v18, argv, envp); std::operatorchar(std::cin, v18); v3 std::operatorstd::char_traitschar(std::cout, -------------------------------------------); std::ostream::operator(v3, std::endlchar,std::char_traitschar); v4 std::operatorstd::char_traitschar(std::cout, Quote from peoples champ); std::ostream::operator(v4, std::endlchar,std::char_traitschar); v5 std::operatorstd::char_traitschar(std::cout, -------------------------------------------); std::ostream::operator(v5, std::endlchar,std::char_traitschar); v6 std::operatorstd::char_traitschar( std::cout, *My goal was never to be the loudest or the craziest. It was to be the most entertaining.); std::ostream::operator(v6, std::endlchar,std::char_traitschar); v7 std::operatorstd::char_traitschar(std::cout, *Wrestling was like stand-up comedy for me.); std::ostream::operator(v7, std::endlchar,std::char_traitschar); v8 std::operatorstd::char_traitschar( std::cout, *I like to use the hard times in the past to motivate me today.); std::ostream::operator(v8, std::endlchar,std::char_traitschar); v9 std::operatorstd::char_traitschar(std::cout, -------------------------------------------); std::ostream::operator(v9, std::endlchar,std::char_traitschar); HighTemplar::HighTemplar((DarkTemplar *)v23, (__int64)v18); v10 std::operatorstd::char_traitschar(std::cout, Checking....); std::ostream::operator(v10, std::endlchar,std::char_traitschar); std::string::basic_string(v19, v18); func1(v20, v19); func2(v21, v20); func3(v21, 0LL); std::string::~string(v21); std::string::~string(v20); std::string::~string(v19); HighTemplar::calculate((HighTemplar *)v23); if ( !(unsigned int)HighTemplar::getSerial((HighTemplar *)v23) ) { v11 std::operatorstd::char_traitschar(std::cout, /////////////////////////////////); std::ostream::operator(v11, std::endlchar,std::char_traitschar); v12 std::operatorstd::char_traitschar(std::cout, Do not be angry. Happy Hacking :)); std::ostream::operator(v12, std::endlchar,std::char_traitschar); v13 std::operatorstd::char_traitschar(std::cout, /////////////////////////////////); std::ostream::operator(v13, std::endlchar,std::char_traitschar); HighTemplar::getFlag[abi:cxx11]((__int64)v22, (__int64)v23); v14 std::operatorstd::char_traitschar(std::cout, flag{); v15 std::operatorchar(v14, v22); v16 std::operatorstd::char_traitschar(v15, }); std::ostream::operator(v16, std::endlchar,std::char_traitschar); std::string::~string(v22); } HighTemplar::~HighTemplar((HighTemplar *)v23); std::string::~string(v18); return 0; }然后我们分析①在倒数第十行出现了flag{在倒数第八行出现了}估计中间就是flag的内容②我们仔细看后发现多出出现了HighTemplar相关的函数我们主要来看倒数第8行之前即可如a. 46行HighTemplar::HighTemplar((DarkTemplar *)v23, (__int64)v18);b.56行HighTemplar::calculate((HighTemplar *)v23);c.57行if ( !(unsigned int)HighTemplar::getSerial((HighTemplar *)v23) )d.65行HighTemplar::getFlag[abi:cxx11]((__int64)v22, (__int64)v23);然后我们双击就可以看到这些函数如下1a. 46行HighTemplar::HighTemplar((DarkTemplar *)v23, (__int64)v18);unsigned __int64 __fastcall HighTemplar::HighTemplar(DarkTemplar *a1, __int64 a2) { char v3; // [rsp17h] [rbp-19h] BYREF unsigned __int64 v4; // [rsp18h] [rbp-18h] v4 __readfsqword(0x28u); DarkTemplar::DarkTemplar(a1); *(_QWORD *)a1 off_401EA0; *((_DWORD *)a1 3) 0; std::string::basic_string((char *)a1 16, a2); std::string::basic_string((char *)a1 48, a2); std::allocatorchar::allocator(v3); std::string::basic_string((char *)a1 80, 327a6c4304ad5938eaf0efb6cc3e53dc, v3); std::allocatorchar::~allocator(v3); return __readfsqword(0x28u) ^ v4; }我们分析发现主要是输入和存储数据的我们要尤其注意存储的数据327a6c4304ad5938eaf0efb6cc3e53dc可能后期进行加密处理2b.56行HighTemplar::calculate((HighTemplar *)v23);bool __fastcall HighTemplar::calculate(HighTemplar *this) { __int64 v1; // rax _BYTE *v2; // rbx bool result; // al _BYTE *v4; // rbx int i; // [rsp18h] [rbp-18h] int j; // [rsp1Ch] [rbp-14h] if ( std::string::length((char *)this 16) ! 32 ) { v1 std::operatorstd::char_traitschar(std::cout, Too short or too long); std::ostream::operator(v1, std::endlchar,std::char_traitschar); exit(-1); } for ( i 0; i (unsigned __int64)std::string::length((char *)this 16); i ) { v2 (_BYTE *)std::string::operator[]((char *)this 16, i); *v2 (*(_BYTE *)std::string::operator[]((char *)this 16, i) ^ 0x50) 23; } for ( j 0; ; j ) { result j (unsigned __int64)std::string::length((char *)this 16); if ( !result ) break; v4 (_BYTE *)std::string::operator[]((char *)this 16, j); *v4 (*(_BYTE *)std::string::operator[]((char *)this 16, j) ^ 0x13) 11; } return result; }我们分析发先主要是进行异或运算的在倒数第四、十二行大概率就是根据这个进行解密加密方法a.倒数十二行先异或0x50在加23b.倒数第四行先异或0x13在加11即解密就是先减11再异或0x13然后再减23再异或0x503c.57行if ( !(unsigned int)HighTemplar::getSerial((HighTemplar *)v23) )__int64 __fastcall HighTemplar::getSerial(HighTemplar *this) { char v1; // bl __int64 v2; // rax __int64 v3; // rax __int64 v4; // rax __int64 v5; // rax unsigned int i; // [rsp1Ch] [rbp-14h] for ( i 0; (int)i (unsigned __int64)std::string::length((char *)this 16); i ) { v1 *(_BYTE *)std::string::operator[]((char *)this 80, (int)i); if ( v1 ! *(_BYTE *)std::string::operator[]((char *)this 16, (int)i) ) { v4 std::operatorstd::char_traitschar(std::cout, You did not pass ); v5 std::ostream::operator(v4, i); std::ostream::operator(v5, std::endlchar,std::char_traitschar); *((_DWORD *)this 3) 1; return *((unsigned int *)this 3); } v2 std::operatorstd::char_traitschar(std::cout, Pass ); v3 std::ostream::operator(v2, i); std::ostream::operator(v3, std::endlchar,std::char_traitschar); } return *((unsigned int *)this 3); }我们分析发现这个是进行验证的验证flag是否正确这是我们基本确定了加密就是上面一步但我们还是看一下第四个函数4d.65行HighTemplar::getFlag[abi:cxx11]((__int64)v22, (__int64)v23);__int64 __fastcall HighTemplar::getFlag[abi:cxx11](__int64 a1, __int64 a2) { std::string::basic_string(a1, a2 48); return a1; }我们分析发现就是获取flag最后我们查看完四个函数后知道有用的就是前两个函数根据这个我们在thonny里编写解密脚本如下temp327a6c4304ad5938eaf0efb6cc3e53dc flag for i in range(len(temp)): nord(temp[i]) flagchr((((n-11)^0x13)-23)^0x50) print(flag{flag})然后我们得到flag为flag{tMx~qdstOs~crvtwb~aOba}qddtbrtcd}

相关文章:

攻防世界 reverse题GFSJ0810-【crazy】

1.工具:exeinfope、IDA Pro (64-bit)、thonny2.解题:下载附件后,我们先在exeinfope里查壳,如下我们发现是64位无壳文件,然后我们把它放到IDA Pro (64-bit)里分析,我们点击F5先查看伪代码,如下代…...

深度解析Cursor试用重置工具:解决“You‘ve reached your trial request limit“的完整方案

深度解析Cursor试用重置工具:解决"Youve reached your trial request limit"的完整方案 【免费下载链接】go-cursor-help 解决Cursor在免费订阅期间出现以下提示的问题: Youve reached your trial request limit. / Too many free trial accounts used on…...

90% LVGL 新手踩大坑!分不清「父子控件」和「Python 子类」

上面我们说到了 LVGL 采用父子对象模型:所有 UI 元素都是 lv.obj 的子类,通过父子关系构建界面层级(屏幕 → 按钮 → 标签),这是新手最容易混淆的两个「父子 / 子类」概念。 首先要明确:LVGL 里的「父子对…...

用Python+OpenCV给斗地主做个‘外挂’:手把手教你写个桌面记牌器(附源码)

PythonOpenCV实战:打造智能斗地主记牌工具 记得去年宿舍通宵打牌时,室友总抱怨记不住出过的牌。作为计算机系学生,我琢磨着能否用课堂学的OpenCV做个记牌工具。三周后,当这个能自动识别桌面上扑克牌的小程序成功运行时&#xff0c…...

使用ComfyUI可视化工作流构建NLP-StructBERT语义搜索应用

使用ComfyUI可视化工作流构建NLP-StructBERT语义搜索应用 你是不是觉得,要搭建一个能理解你说话、能精准搜索内容的AI应用,得写一堆复杂的代码,还得懂各种框架?其实,现在有更简单的方法了。今天,我就带你用…...

Rustup离线安装完整指南:在没有网络的环境中搭建Rust开发平台

Rustup离线安装完整指南:在没有网络的环境中搭建Rust开发平台 【免费下载链接】rustup The Rust toolchain installer 项目地址: https://gitcode.com/gh_mirrors/ru/rustup 你是否曾经需要在完全隔离的网络环境中安装Rust开发工具链?&#x1f91…...

Windows安全中心总提示驱动不兼容?手把手教你清理老旧驱动,为内存完整性扫清障碍

Windows驱动深度清理指南:彻底解决内存完整性兼容性问题 每次打开Windows安全中心,那个刺眼的"驱动不兼容"提示总让人心烦?这不仅仅是烦人的弹窗问题,更是系统安全与性能的潜在威胁。作为长期使用Windows的资深用户&…...

技术探索:硬件信息伪装的内核级实现方案

技术探索:硬件信息伪装的内核级实现方案 【免费下载链接】EASY-HWID-SPOOFER 基于内核模式的硬件信息欺骗工具 项目地址: https://gitcode.com/gh_mirrors/ea/EASY-HWID-SPOOFER 如何通过驱动级操作实现系统硬件标识的深度修改? 技术解析&#x…...

炸裂实锤!随手乱按挖出编译器「乱码隐藏保留字」编译报错直接封神

文章目录封面文案一、专栏开篇回顾二、初见疑点:反复刷屏的神秘乱码片段三、三层硬核现场取证,逐层锁死真相1. IDE标识实锤:专属K图标 关键字同款高亮2. 编译现场终极定罪:报错和普通未定义变量完全不同对比区分,一眼…...

【java --mybatis-flex】

基本信息 https://mybatis-flex.com/zh/others/codegen.html 基于mybatis,支持 Entity 的增删改查、以及分页查询的同时,MyBatis-Flex 提供了 Db Row^灵活 工具,可以无需实体类对数据库进行增删改查以及分页查询。 与此同时,MyBa…...

国产隔离器信号孤岛保卫战

国产隔离器正以绝缘屏障铸就信号孤岛——当8kV静电在光伏接线盒上炸出刺目蓝光,当10V/m射频噪声如潮水般淹没地铁信号回波,这条工业设备的生死线上,我们以GB/T 17626标准为矛,以-40℃~85℃环境适应性为盾,在电磁风暴与…...

为什么事故复盘总是写到很晚?

这两天和几个做运维/后端的朋友聊了下事故复盘,发现一个很真实的情况: 👉 大家都知道复盘很重要 👉 但几乎没人愿意写 我问了一个问题: “为什么一份复盘总是要写那么久?” 总结下来基本都是这几个原因&…...

如何彻底掌控Windows Defender:终极禁用与启用指南

如何彻底掌控Windows Defender:终极禁用与启用指南 【免费下载链接】defender-control An open-source windows defender manager. Now you can disable windows defender permanently. 项目地址: https://gitcode.com/gh_mirrors/de/defender-control 你是…...

NRBO - Transformer - BiLSTM回归:Matlab实现的数据预测魔法

NRBO-Transformer-BiLSTM回归 Matlab代码 基于牛顿拉夫逊优化算法优化Transformer结合双向长短期记忆神经网络(BiLSTM)的数据回归预测(可以更换为分类/单、多变量时序预测/回归,前私我),Matlab代码,可直接运行,适合小白新手 程序已…...

Z-Image-Turbo LoRA Web服务GPU优化:显存碎片整理与长期运行稳定性保障

Z-Image-Turbo LoRA Web服务GPU优化:显存碎片整理与长期运行稳定性保障 1. 项目概述与核心价值 今天要跟大家分享的是一个基于Z-Image-Turbo模型的图片生成Web服务,重点解决了GPU显存管理和长期稳定运行的关键问题。这个服务不仅支持高质量的图片生成&…...

Openclaw 股票分析助手,自定义选股+情绪预警实时推送

最近我越来越觉得,炒股这件事,难的不是完全看不懂,而是你根本没那么多时间,把该看的东西全都看一遍。平时工作忙一点,白天不是在开会,就是在处理各种事情。别说一直盯着盘面了,有时候连行情软件…...

CG迷李辰全面掌握ComfyUI系统教程2025年结课(超清画质带大部分素材)

全面掌握 ComfyUI:AI 设计变现新技能,经济收益深度解析在生成式人工智能(AIGC)从“尝鲜玩具”向“生产力工具”转型的2025-2026年,设计行业的经济逻辑正在经历一场剧烈的重构。当简单的文本生成图像(Text-t…...

PP-DocLayoutV3产业应用效果:金融票据与医疗报告的结构化

PP-DocLayoutV3产业应用效果:金融票据与医疗报告的结构化 每次看到财务同事抱着一沓厚厚的银行流水单手动录入数据,或者医生在成堆的化验单里翻找关键指标,我就在想,这事儿能不能让机器来干?过去,文档智能…...

技能组合艺术:OpenClaw串联QwQ-32B实现复杂工作流

技能组合艺术:OpenClaw串联QwQ-32B实现复杂工作流 1. 为什么需要工作流串联 当我第一次接触OpenClaw时,最让我兴奋的不是它能完成某个单一任务,而是它能够将多个技能像乐高积木一样组合起来。这种能力让我想到了现实工作中的场景——很少有…...

基于北方苍鹰优化算法优化径向基函数神经网络(NGO - RBF)的时间序列预测

基于北方苍鹰优化算法优化径向基函数神经网络(NGO-RBF)的时间序列预测 NGO-RBF时间序列 优化参数为扩散速度,采用交叉验证防止过拟合 matlab代码注:暂无Matlab版本要求 -- 推荐 2018B 版本及以上在时间序列预测领域,寻找高效准确的模型一直是…...

MongoDB从零基础搭建到实战

MongoDB从零基础搭建到实战 MongoDB作为当下最流行的开源文档型NoSQL数据库,凭借灵活的文档结构、高扩展性和易用性,成为前后端开发、大数据存储、云原生项目的首选数据库之一。相比传统关系型数据库,它无需严格预定义表结构,适配…...

医用擦拭纸选购指南:看懂这五大认证,避开医疗耗材采购“隐形坑

# 医用擦拭纸选购指南:看懂这五大认证,避开医疗耗材采购“隐形坑”> 在医疗领域,每一片看似普通的擦拭纸,都直接关系到诊疗安全、院感控制和患者健康。对于医疗器械经销商、医院后勤管理者而言,选择供应商时最核心的…...

Vivado综合策略的‘隐藏菜单’:手把手教你用TCL定制专属策略,榨干UltraScale+性能

Vivado综合策略的‘隐藏菜单’:手把手教你用TCL定制专属策略,榨干UltraScale性能 当你在Vivado中点击"Run Synthesis"时,是否曾好奇那些预设策略背后究竟发生了什么?对于大多数FPGA设计,Vivado提供的预设策略…...

Verilog新手避坑指南:从HDLBits的Getting Started到Vectors,我踩过的那些坑

Verilog新手避坑指南:从HDLBits的Getting Started到Vectors,我踩过的那些坑 第一次接触Verilog时,我像大多数初学者一样,被它既像C语言又不像C语言的语法搞得晕头转向。HDLBits这个在线练习平台确实是个好帮手,但当我从…...

2026 GitHub 高星项目全景指南

一、GitHub 全球 Star 最高项目(2026年3月 实时数据) GitHub 无官方总 Star 榜单,以下为综合第三方统计与实时检索的全球高星项目 Top10,数据动态更新,以仓库主页为准: 排名 项目名称 Star 数 核心定位 1 build-your-own-x ⭐47.4万+ 从零实现各类技术的教程合集 2 awes…...

openclaw喂饭教程!在 Linux 环境下快速完成安装、初始化与 Web UI 配置

基础示例:单工作表 Excel 转 TXT 以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤: 1. 加载并读取Excel文件 from spire.xls import * from spire.xls.common import * workbook Workbook() workbook.LoadFromFile("示例.xlsx"…...

松江少儿英语口碑好的?

松江少儿英语口碑好的 环球乐学少儿英语,指出幼儿英语学习三大痛点: 1. 兴趣不足易抵触:教学形式枯燥,多以机械记单词、跟读为主,不符合幼儿认知特点,易产生厌学情绪。 2. 缺语境不会运用&#xff1a…...

DTII(A) 9.12.2、带调节挡板漏斗

示意图主视图侧视图C向法兰口Z向:操纵杆安装位置【说明】【表9-48】带调节挡板漏斗相关参数参数说明其它参数同 “普通漏斗”;【L5】调节挡板底座 与 漏斗壁 距离。【260】调节挡板底座长度。【注意】...

FastAdmin框架旧版本踩坑记:手把手教你修复那个能读任意文件的CVE-2024-7928漏洞

FastAdmin框架安全实战:深度解析CVE-2024-7928漏洞修复与防御策略 当安全扫描报告突然标红显示"FastAdmin框架存在任意文件读取漏洞(CVE-2024-7928)"时,作为项目负责人的你可能会瞬间心跳加速。这个看似简单的漏洞编号背…...

掌握Agentic RAG:动态智能代理,提升大模型学习与实战效率,CSDN小白程序员必收藏!

掌握Agentic RAG:动态智能代理,提升大模型学习与实战效率,CSDN小白程序员必收藏! Agentic RAG技术通过引入自主AI代理,解决了传统RAG系统依赖静态数据的局限性,实现实时检索最新数据,灵活调整策…...