第二道re

题目来源:天狩CTF竞赛平台 Lihua's for

题目提示说是for循环,不管了干吧

先看加没加壳,没有,直接无脑IDA+F5

代码功能概述

程序会要求用户输入一个 flag,然后将输入的每个字符与索引值进行异或运算,并将结果与预定义的数据(unk_403040)进行比较。如果所有字符都匹配,则输出 "good~",否则输出 "error!"。

cpp 复制代码
 _main();
  qmemcpy(a, &unk_403040, sizeof(a));
  // 从地址0x403040复制 42 字节数据到数组a中,这是预定义的目标数据。

  puts("input flag");
  scanf("%s", flag);
  // 提示用户输入 flag,并读取字符串到flag数组中。

  puts(flag);
  for ( i = 0; i <= 41; ++i )
    b[i] = i ^ flag[i];
  // 对输入的每个字符进行处理:将字符与它的索引位置进行异或运算,结果存入数组b。
  for ( i_0 = 0; i_0 <= 41; ++i_0 )
  {
    if ( a[i_0] != b[i_0] )
    {
      good = 0;
      break;
    }
    good = 1;
  }
  if ( good == 1 )
    printf("good~");
  else
    printf("error!");
  return 0;
}
  /* 逐个比较异或结果b与预定义数据a:
  如果有任何不匹配,将good设为 0 并跳出循环。
  只有当所有字符都匹配时,good才会保持为 1 */

点进去&unk_403040这个值里面,发现有字符串

红框框就是我们要找的数据,下面还有,一共是42个,我们把它们的十六进制提取出来

把这些十六进制写成一个列表,对它们进行异或运算:

python 复制代码
a = [0x66,0x6D,
     0x63,0x64,0x7F,0x64,
     0x32,0x36,0x6A,0x6C,
     0x3E,0x3D,0x39,0x20,
     0x6F,0x3A,0x20,0x77,
     0x3F,0x27,0x25,0x27,
     0x22,0x3A,0x7A,0x2E,
     0x78,0x7A,0x31,0x2F,
     0x29,0x29,0x16,0x40,
     0x44,0x45,0x12,0x47,
     0x47,0x41,0x1A,0x54]
c = ""
b = 0
for i in a:
    c += chr(b ^ i)
    b += 1
print(c)

运行就出来flag了

bash 复制代码
flag{a41be465-a50f-4124-b7ba-2766aff6baf2}
相关推荐
weixin_408099672 分钟前
OCR 识别率提升实战:模糊 / 倾斜 / 反光图片全套优化方案(附 Python / Java / PHP 代码)
图像处理·人工智能·后端·python·ocr·api·抠图
翻斗包菜4 分钟前
Python 网络编程从入门到精通:TCP/UDP/Socket 实战详解
网络·python·tcp/ip
七颗糖很甜17 分钟前
雨滴谱数据深度解析——从原始变量到科学产品的Python实现【下篇】
python·算法·pandas
爱码小白18 分钟前
MySQL 常用数据类型的系统总结
数据库·python·算法
xcbrand22 分钟前
专精特新品牌全案公司有哪些
大数据·人工智能·python
橘子编程27 分钟前
GoF 23 种设计模式完整知识总结与使用教程
java·c语言·开发语言·python·设计模式
枫叶林FYL30 分钟前
【Python高级工程与架构实战】项目五:生产级LLM Agent框架:基于PydanticAI的类型安全企业级实现
python·安全·架构
ths51230 分钟前
Python 正则表达式学习笔记(小白超详细版)(一)
python·正则表达式
飞Link35 分钟前
pprint 全量技术手册:复杂数据结构的结构化输出引擎
开发语言·前端·python
培风图南以星河揽胜40 分钟前
幻想简历!博主本人期望的 AI Agent 全栈简历:Java + Python + Vue3 跨语言实战,代码已开源!
java·人工智能·python