[攻防世界]EasyRE

[攻防世界]EasyRE

解析

先查壳,是32位无壳的。
在这里插入图片描述
拖入ida中,没有main函数,查找字符串,看见一个flag,但是是假flag。
在这里插入图片描述
直接运行一下,发现最开始是input,那么直接就从imput开始进入查看逻辑,之后稍微修改一个,让代码看起来更易读。

int sub_401080()
{
  unsigned int input_len; // kr00_4
  signed int len_dx; // edx
  char *v2; // esi
  char v3; // al
  unsigned int len_s; // edx
  int v5; // eax
  __int128 input; // [esp+2h] [ebp-24h]
  __int64 v8; // [esp+12h] [ebp-14h]
  int v9; // [esp+1Ah] [ebp-Ch]
  __int16 v10; // [esp+1Eh] [ebp-8h]

  sub_401020((int)&unk_402150);
  v9 = 0;
  v10 = 0;
  input = 0i64;
  v8 = 0i64;
  sub_401050((const char *)&unk_402158, &input);// 输入的给input
  input_len = strlen((const char *)&input);     // 获取input的长度
  if ( input_len >= 16 && input_len == 24 )     // 长度要大于16等于24
  {
    len_dx = 0;
    v2 = (char *)&v8 + 7;
    do
    {
      v3 = *v2--;                               // 反过来
      byte_40336C[len_dx++] = v3;
    }
    while ( len_dx < 24 );
    len_s = 0;
    do
    {
      byte_40336C[len_s] = (byte_40336C[len_s] + 1) ^ 6;// 加一异或
      ++len_s;                                  // 自加一
    }
    while ( len_s < 24 );
    v5 = strcmp(byte_40336C, "xIrCj~<r|2tWsv3PtI\x7Fzndka");// 对比
    if ( v5 )
      v5 = -(v5 < 0) | 1;
    if ( !v5 )
    {
      sub_401020((int)"right\n");
      system("pause");
    }
  }
  return 0;
}

知道了逻辑是你写入的先看长度,24时候倒叙一下,之后加一异或,那么反着写一下。

脚本

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<stdint.h>
char aXircjR2twsv3pt[25] = "xIrCj~<r|2tWsv3PtI\x7Fzndka";
char flag[25] = { 0 };
int main() {
	for (size_t i = 0; i < 24; i++) {
		flag[i] = (aXircjR2twsv3pt[23-i] ^ 6) - 1;
	}
	printf("%s", flag);
	return 0;
	
}

最后获得flag是flag{xNqU4otPq3ys9wkDsN}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

逆向萌新

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值