2023西湖论剑RE--BabyRE

用IDA打开附件,搜索字符串发现“Good, flag is DASCTF{your input}”字符串

一直交叉引用,发现以下三个函数

下面分析中的部分函数名,变量名和变量类型我做了修改

一、sub_401000函数

该函数先调用sub_401170函数,然后注册了一个退出函数sub_405770

进入sub_401170函数:该函数逻辑为输入字符串到Input,输入字符在'0'~'9'之间

进入sub_405770函数,最后跟踪到一个rc4算法函数

算法逻辑,首先将Input_base8(经过处理的Input)复制给data,大小为112(0x70),然后对data数据进行rc4加密,密钥长度为6。最后将加密的data与cipher比较,如果相等则sucess!

所以我们需要做的是将cipher进行解密得到data(即Input_base8),然后对解密后的data进行某种处理即可得到flag

其中cipher数据如下:

二、sub_401050函数

该函数先调用sub_401230函数,然后注册了一个退出函数sub_4057B0

进入sub_401230函数:该函数逻辑为将table_0_7数组的值取反

其中table_0_7内容如下:对其取反后变成0 1 2 3 4 5 6 7

进入sub_4057B0函数:该函数调用了sub_401CC0函数,跟进该函数可以发现该函数并没有对Input_base8进行处理

三、sub_4010A0函数

该函数先调用sub_4012B0函数,然后注册了一个退出函数sub_4057F0

进入sub_4012B0函数:取了句柄,加载dll,具体不知道干了啥,但这不影响

进入sub_4057F0函数:跟踪到sub_401670函数,可以看到这里有一个base_8函数对Input进行了处理,跟进base_8看看。

进入base_8函数:这个算法很简单,跟base64差不多。这里的table_0_7经过前面的分析知道是一个0~7的表。该函数就是把一个字符串每三个比特位变成一个8进制数,不足3位则在后面补0。

eg:字符串123 其二进制为:00110001 00110010 00110011 则三个为一组:

001 100 010 011 001 000 110 011 ==>14231063

综上分析:

Input 经过base_8编码 经过rc4加密 得到 cipher。所以:将cipher经过rc4解密 base_8解码后即可得到flag

cipher已知 所以只需要得到rc4解密(加密,rc4为对称加密算法)时的密钥即可,但可以发现存储的key的值为0。这里我以为这里的key是在运行时动态生成的,但在IDA中没有发现对key进行操作的算法,动态调试时也没有发现。后来发现Input与key的地址是靠在一起的。

所以这里就明白了,key也是由我们进行输入,从Input到key中间是相差42,所以我们输入的Input应该为48位,后6为就会作为key,而经过前面分析Input的值只能在'0'~'9'之间,也就是说key的值也只能在'0'~'9'之间,所以这里的key可以直接进行爆破。

exp:其中base_8的逆函数的C语言代码是由chatgpt编写,python代码为我自己编写,我写的那个base_8解码函数是存在一定问题的,因为我没有考虑位数不足八位的情况,但是这个题目不影响,因为这个题目位数恰好是8的倍数。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include "crypt.h"char* base_8_decode(char* encoded_str);unsigned char cipher[] =
{0x3F, 0x95, 0xBB, 0xF2, 0x57, 0xF1, 0x7A, 0x5A, 0x22, 0x61,0x51, 0x43, 0xA2, 0xFA, 0x9B, 0x6F, 0x44, 0x63, 0xC0, 0x08,0x12, 0x65, 0x5C, 0x8A, 0x8C, 0x4C, 0xED, 0x5E, 0xCA, 0x76,0xB9, 0x85, 0xAF, 0x05, 0x38, 0xED, 0x42, 0x3E, 0x42, 0xDF,0x5D, 0xBE, 0x05, 0x8B, 0x35, 0x6D, 0xF3, 0x1C, 0xCF, 0xF8,0x6A, 0x73, 0x25, 0xE4, 0xB7, 0xB9, 0x36, 0xFB, 0x02, 0x11,0xA0, 0xF0, 0x57, 0xAB, 0x21, 0xC6, 0xC7, 0x46, 0x99, 0xBD,0x1E, 0x61, 0x5E, 0xEE, 0x55, 0x18, 0xEE, 0x03, 0x29, 0x84,0x7F, 0x94, 0x5F, 0xB4, 0x6A, 0x29, 0xD8, 0x6C, 0xE4, 0xC0,0x9D, 0x6B, 0xCC, 0xD5, 0x94, 0x5C, 0xDD, 0xCC, 0xD5, 0x3D,0xC0, 0xEF, 0x0C, 0x29, 0xE5, 0xB0, 0x93, 0xF1, 0xB3, 0xDE,0xB0, 0x70
};unsigned char key[256];
unsigned char data[256];
unsigned char s[256];int check_is_valid() {//printf("checking...\n");for (int i = 0; i < 112; ++i) {    if (data[i] < '0' || data[i] > '9') return 0;}printf("key:%s\ndata:%s\n", key, data);char *x = base_8_decode((char *)data);printf("flag:%s%s\n", x, key);return 1;
}void dfs(char k, int l) {key[l] = k;int flag = 0;if (l == 5) {rc4_init(s, key, 6);for (int i = 0; i < 112; i++) data[i] = cipher[i];rc4_crypt(s, data, 112);flag = check_is_valid();return;}if (flag) return;for (int i = '0'; i <= '9'; i++) dfs(i, l + 1);}char* base_8_decode(char* encoded_str) {int encoded_len = strlen(encoded_str);int decoded_len = encoded_len / 2 * 3 + ((encoded_len % 2 == 0) ? 0 : ((encoded_len % 4 == 1) ? 1 : 2));char* decoded_str = (char*)malloc(decoded_len + 1);int idx1 = 0, idx2 = 0, idx3 = 0;while (idx1 < encoded_len) {// Decode three characters at a timechar c1 = encoded_str[idx1++];char c2 = encoded_str[idx1++];char c3 = encoded_str[idx1++];char c4 = encoded_str[idx1++];char c5 = encoded_str[idx1++];char c6 = encoded_str[idx1++];char c7 = encoded_str[idx1++];char c8 = encoded_str[idx1++];char b1 = (c1 - '0') << 5 | (c2 - '0') << 2 | (c3 - '0') >> 1;char b2 = (c3 - '0') << 7 | (c4 - '0') << 4 | (c5 - '0') << 1 | (c6 - '0') >> 2;char b3 = (c6 - '0') << 6 | (c7 - '0') << 3 | (c8 - '0');decoded_str[idx2++] = b1;if (idx1 <= encoded_len && c4 != '=') decoded_str[idx2++] = b2;if (idx1 <= encoded_len && c7 != '=') decoded_str[idx2++] = b3;}decoded_str[idx2] = '\0';return decoded_str;
}int main(int argc, char *argv[]) {for (int i = '0'; i <= '9'; i++) dfs(i, 0);return 0;
}
//rc4算法即crypt.h头文件中函数的实现
unsigned char old_s[256] = { 0 };void swap(unsigned char *s, int i, int j) {unsigned char tmp = 0;tmp = s[i];s[i] = s[j];s[j] = tmp;
}unsigned char* rc4_init(unsigned char *s, unsigned char *key, unsigned long Len) {int i = 0, j = 0;char k[256] = { 0 };for (; i < 256; i++) {s[i] = i;k[i] = key[i%Len];}for (i = 0; i < 256; i++) {j = (j + s[i] + k[i]) % 256;swap(s, i, j);}//用old_s[i]暂时保留经过初始化的s[i]for (i = 0; i < 256; i++) {old_s[i] = s[i];}return old_s;
}void rc4_crypt(unsigned char *s, unsigned char *Data, unsigned long Len) {int i = 0, j = 0, t = 0;unsigned long k = 0;for (; k < Len; k++) {i = (i + 1) % 256;j = (j + s[i]) % 256;swap(s, i, j);t = (s[i] + s[j]) % 256;Data[k] ^= s[t];}
}
#base_8解码函数python代码
#rc4_cipher为cipher经过rc4解密后的值
#key为爆破出来的的密钥
rc4_cipher = "1523306115230466162304651523346214431471150310701503207116032063140334661543446114434066142304661563446615430464"
key = "807391"
bin_cipher = ""
for i in rc4_cipher:bin_cipher += str(bin(int(i)))[2:].rjust(3,'0')
print(bin_cipher)
i = 0
flag = ""
while i < len(bin_cipher):w = chr(int(bin_cipher[i:i+8],2))if w != "=":flag += wprint(flag)i += 8
flag += key
print("flag is DASCTF" + "{" + flag + "}")

结果如下:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/16969.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AIGC专题二:ChatGPT更懂人类的叙事

ChatGPT是OpenAI推出的聊天机器人模型&#xff0c;月度用户已破亿&#xff0c;正在逐步探索商业化途径。ChatGPT能够通过学习和理解人类的语言来进行对话&#xff0c;还能根据聊天的上下文进行互动&#xff0c;真正像人类一样来聊天交流&#xff0c;甚至能完成撰写邮件、视频脚…

【ARMv8/v9 异常模型入门及渐进2 - 系统控制寄存器 SCTRL_ELx 介绍】

文章目录 SCTRL_ELx 介绍背景ARMv8 SCTLR_ELx 介绍ARMv9 SCTLR_ELx 介绍 SCTRL_ELx 介绍背景 由于在做DFD 测试过程中需要测试 EL1 状态下的 self-hosted trace 功能&#xff0c;但是这个测试是在UEFI中做的&#xff0c;在开发验证阶段UEFI默认是运行在EL3 下的&#xff0c;所…

关于UVC设备拥有两个/dev/video*节点的原因以及来历?

在ubuntu18.04/ubuntu16.04系统上,插入UVC设备,你会发现V4L2框架替它创建了两个video设备节点,分别是 /dev/video0, /dev/video1: 经过实际测试,可以通过/dev/video0获取图像,但是无法通过/dev/video1获取图像,具体的试验请看下面两篇博客: V4L2子系统架构设计初探 美…

从千亿模型到ChatGPT的⼀点思考

近年来人工智能的快速发展受到社会各界的广泛关注&#xff0c;超大规模预训练模型取得了突飞猛进的进步。唐杰从OpenAI发布的大规模自然语言预训练模型GPT-3谈起&#xff0c;详细介绍了大模型的进化史&#xff0c;及其所表现出来的能够更好处理现实世界复杂性问题的能力与可能性…

230502-LLM-Vicuna介绍、安装与注意事项整理

排名模型Elo 得分描述许可证1&#x1f947; GPT-41274OPENAI 公司&#xff1a;ChatGPT-4OpenAI公司专有2&#x1f948;Claude-v11224Anthtopic 公司&#xff1a;ClaudeAnthtopic公司专有3&#x1f949; GPT-3.5-turbo1155OPENAI 公司&#xff1a;ChatGPT-3.5OpenAI公司专有4⭐️…

ChatGPT又为我省了一笔钱

作为家长你可能会关注。我周围的朋友&#xff0c;一般都会请外教来帮助孩子提高英语口语能力。然而&#xff0c;外教的费用不菲&#xff0c;这也成为了很多人的负担。但现在&#xff0c;有了ChatGPT语音插件&#xff0c;我们可以省下雇佣外教的钱&#xff0c;而又能有效地提高英…

跟着ChatGPT手把实现一个websocket连接管理器! 毛骨悚然

全是贴图了&#xff1a; 多说无益&#xff01;&#xff01;&#xff01; 开始&#xff1a; 实现一个某安的连接管理&#xff1a; 其中步骤1到7列的明明白白&#xff0c;而且一开始就提出了要有connectionManager&#xff0c;这已经是很职业的方式了&#xff0c;至少不是学生气&…

2023 商业化ChatGpt Web源码

简介 一款使用React搭建的一款可商业化的ChatGpt Web应用,支持接入支付宝当面付及易支付 主要功能 后台管理系统,可对用户,Token,商品,卡密等进行管理精心设计的 UI&#xff0c;响应式设计极快的首屏加载速度&#xff08;~100kb&#xff09;支持Midjourney绘画和DALLE模型绘…

基于ChatGPT的文档知识库客服系统-支持上传网址/文本/docx等数据

现在&#xff0c;很多公司都有自己的内容知识库&#xff0c;会产生大量的碎片话的内部知识&#xff0c;但是这样内部知识难以整合搜索。 我开发的文档知识库客服系统 gofly.v1kf.com &#xff0c;可以应用于企业内部知识库管理&#xff0c;用户可以使用自然语言提问&#xff0c…

学编程一定要数学很好吗?看到网友这样说,我松了一口气 ...

学好数理化&#xff0c;走遍全天下&#xff01;小时候&#xff0c;这句顺口溜时常在耳边响起&#xff0c;而迈入编程行业以后&#xff0c;又有人想问&#xff1a;我数学不好&#xff0c;能写好代码吗&#xff1f; 不过最近的 MIT 神经科学家在 eLife期刊发表了一项新研究&#…

答读者:数学不好,能学好算法吗?

点击关注上方“五分钟学算法”&#xff0c; 设为“置顶或星标”&#xff0c;第一时间送达干货。 转自是不是很酷 这是在我的知识星球上&#xff0c;一个同学问我的问题。 波波老师您好。 我今年 28 了&#xff0c;也算是科班出身&#xff0c;但是大学的时候基本没怎么上过课。毕…

5小时掌握提示词工程,写出高价值大模型Prompt!中文!免费!

写出优质的提示词&#xff0c;让AI生成惊艳的图文作品。 ——这就是如今年薪百万仍一人难求的提示词工程师们在解决的问题。大语言模型时代下&#xff0c;不断涌现出众多让人瞳孔地震的绘画、拍案叫绝的文案&#xff0c;它们的创作者并非传统定义的画家、作家&#xff0c;而是这…

大模型部署的方案

借着热点&#xff0c;简单聊聊大模型的部署方案&#xff0c;作为一个只搞过CV部署的算法工程师&#xff0c;在最近LLM逐渐改变生活的大背景下&#xff0c;猛然意识到LLM部署也是很重要的。大模型很火&#xff0c;而且确实有用&#xff08;很多垂类场景可以针对去训练&#xff0…

大大大模型部署方案抛砖引玉

作者 | Oldpan 编辑 | oldpan博客 点击下方卡片&#xff0c;关注“自动驾驶之心”公众号 ADAS巨卷干货&#xff0c;即可获取 点击进入→自动驾驶之心【模型部署】技术交流群 借着热点&#xff0c;简单聊聊大模型的部署方案&#xff0c;作为一个只搞过CV部署的算法工程师&#…

为什么很多企业把35岁视为分水岭

(点击即可收听) 为什么很多企业把35岁视为分水岭 有时候,别人的故事,若干年后,就是自己的故事,只要身在互联网这个行业里,可以说,每个人都避免不了35岁危机 不要五十步笑百步 前阵子,朋友圈一位行业知名大佬,35岁,每天兢兢业业,任劳任怨,本以为安稳渡过3个月试用期,正快要转正时…

AI冲击人工:资深翻译3年前就接受了可能到来的失业,原画师被取代后又出现了“AI概念师”...

九派新闻AI会取代我们吗&#xff1f; 高盛公司最新一份研究报告指出&#xff0c;ChatGPT等AI领域出现突破后&#xff0c;全球预计将有3亿个工作岗位被生成式AI取代。OpenAI近日发表论文称&#xff0c;如果一项工作使用AI能减少50%以上的时间&#xff0c;那么它就是可替代的。其…

项目完成小结:使用Blazor和gRPC开发大模型客户端

先介绍下这个项目。 最近我一直在探索大语言模型&#xff0c;根据不同场景训练了好几个模型&#xff0c;为了让用户测试使用&#xff0c;需要开发前端。 这时候&#xff0c;用 Gradio 搭建的前端是不太够的&#xff0c;虽说 GitHub 上也有一堆开源的 ChatGPT 前端&#xff0c…

Mac 上的搜狗输入法卡顿问题

我的 Mac 使用的中文输入法是搜狗拼音输入法&#xff0c;一直有一个问题&#xff0c;就是 Mac 开机太久&#xff0c;输入法会出现卡顿问题&#xff0c;按下按键 0.5s 后需才会显示对应的汉字&#xff0c;用着非常难受&#xff0c;以前这种情况我都是通过重启 Mac 来解决&#x…

大语言模型将如何影响软件开发?

当人人具备编写代码的能力之后&#xff0c;这将会给软件生产和分配带来哪些结构性的变化&#xff1f; 原文链接&#xff1a;https://www.geoffreylitt.com/2023/03/25/llm-end-user-programming.html 未经授权&#xff0c;禁止转载&#xff01; 作者 | Geoffrey Litt 译者 | 弯…

提示词工程让儿童编程轻而易举

编写长长的代码时常令人头疼。尤其是小朋友&#xff0c;打字不快&#xff0c;但想象力丰富。 现在借助chatgpt。 一切变得超级简单。 1. https://github.com/roocell/gptCozmo 2. https://github.com/Bhood23/CozmoGPT while True:from pyChatGPT import ChatGPTimport speec…