首页 > 其他 > 详细

HWS2021 RE_decription

时间:2021-02-01 23:18:26      阅读:53      评论:0      收藏:0      [点我收藏+]

直接暴力的签到题。

解题步骤:

先F5找主函数

 
 
 
?x
 
 
 
 
int __cdecl main(int argc, const char **argv, const char **envp)
{
  int v4; // [esp+18h] [ebp-CCh]
  int v5; // [esp+1Ch] [ebp-C8h]
  int v6; // [esp+7Ch] [ebp-68h]
  int v7; // [esp+80h] [ebp-64h]
?
  __main();
  v6 = 0;
  memset(&v7, 0, 0x60u);
  printf("Please input your flag:");
  scanf("%s", &v6);
  if ( strlen((const char *)&v6) != 32 )//flag 长度为32
  {
    puts("Wrong!");
    system("pause");
    exit(0);
  }
  v4 = 0;
  memset(&v5, 0, 0x60u);
  encrypt((unsigned __int8 *)&v4, (char *)&v6);//显然这里应该是一个解密运算,将v6的数据转移到v4上
  if ( !memcmp(&v4, &buf, 0x20u) )//cmp
  {
    puts("Orz!666!");
    printf("Here is your flag: flag{%s}\n", &v6);
  }
  else
  {
    puts("Sorry, try again~");
  }
  system("pause");
  return 0;
}
 

再看看解密函数encrypt()里面:

 
 
 
xxxxxxxxxx
 
 
 
 
unsigned __int8 *__cdecl encrypt(unsigned __int8 *a1, char *a2)
{
  char a; // ST09_1
  char v3; // ST08_1
  char c; // ST08_1
  unsigned __int8 *result; // eax
  char t; // [esp+Ah] [ebp-6h]
  char b; // [esp+Bh] [ebp-5h]
  signed int i; // [esp+Ch] [ebp-4h]
?
  for ( i = 0; i <= 31; ++i )
  {
    a = i ^ a2[i];//无用
    v3 = i & a2[i];                             // 无用语句
    b = a2[i];
    t = i;
    do
    {
      c = 2 * (t & b);
      b ^= t;
      t = c;
    }
    while ( c );
    result = &a1[i];
    a1[i] = b ^ 0x23;c
  }
  return result;
}
 

这里我们选择枚举每一位把flag试出来,枚举的范围应该试可见字符,即32~127。

解题脚本:

python:

 
 
 
xxxxxxxxxx
 
 
 
 
# HWS_RE_decryption
s1 = ""
s2 = [18, 69, 16, 71, 25, 73, 73, 73, 26, 79, 28, 30, 82, 102, 29, 82, 102, 103, 104, 103, 101, 111, 95, 89, 88, 94,
      109, 112, 161, 110, 112, 163]
for i in range(32):
    for j in range(32, 127):
        b = j
        t = i
        while(True):
            c = 2 * (t & b)
            b ^= t
            t = c
            if(c == 0):
                break
        if (b ^ 0x23 == s2[i]):
            s1 += chr(j)
            break
print(s1)
?
 

c++:

 
 
 
xxxxxxxxxx
 
 
 
 
#include<cstdio>
#include<iostream>
#include<cmath>
#include<algorithm>
using namespace std;
char a[32];//33-126可见字符 
char s2[32] = {18, 69, 16, 71, 25,73,73,73, 26, 79, 28, 30, 82,102, 29, 82,102,103,104,103,101,111, 95, 89, 88, 94,109,112,161,110,112,163};
bool check(int i)
{
unsigned int c,b,t;
for(unsigned int j = 33;j<=126;j++){
b = j;
t = i;
do{
c = 2 *(t & b);
b ^= t;
t = c;
}while(c); 
char chr = b ^ 0x23;
if(chr == s2[i]){
a[i] = j;
break;
}
}
}
int main()
{
for(int i = 0;i <= 31;i++)
check(i);
for(int i = 0;i < 32;i++){
printf("%c",a[i]);
}
return 0;
}
 

 

HWS2021 RE_decription

原文:https://www.cnblogs.com/BlankSpace/p/14359486.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!