做题笔记。
下载 查壳
32ida打开。
先看main函数:
(自己改已知的函数名--->不再赘述)
跟进sub_4011C0:
在已知密文的情况下,直接逆向还原去得到input的值。
C脚本:
#include <stdio.h>
#include <string.h>
int main() {
unsigned char a[] =
{
13, 19, 23, 17, 2, 1, 32, 29, 12, 2,
25, 47, 23, 43, 36, 31, 30, 22, 9, 15,
21, 39, 19, 38, 10, 47, 30, 26, 45, 12,
34, 4
};
char b[25] = "GONDPHyGjPEKruv{{pj]X@rF";
char c[25] = " ";
char flag[25] = " ";
for (size_t i = 0; i <strlen(b); i++)
{
c[i] = b[i] ^ a[i];
flag[i] = (c[i] - 72) ^ 0x55;
}
for (int i = 0; i < strlen(flag); i++)
{
if (flag[i]>='a'&& flag[i]<='z')
{
flag[i] -= 32;
}
else if(flag[i]>='A' && flag[i]<='Z')
{
flag[i] += 32;
}
}
printf("EIS{%s}", flag);
return 0;
}
Python:
a = [13, 19, 23, 17, 2, 1, 32, 29, 12, 2, 25, 47, 23, 43, 36, 31, 30, 22, 9, 15, 21, 39, 19, 38, 10, 47, 30, 26, 45, 12, 34, 4]
b = "GONDPHyGjPEKruv{{pj]X@rF"
c = [chr(ord(b[i]) ^ a[i]) for i in range(len(b))]
flag = [chr(((ord(c[i]) - 72) ^ 0x55)) for i in range(len(c))]
def adjust_char(char):
if 'a' <= char <= 'z':
return chr(ord(char) - 32)
elif 'A' <= char <= 'Z':
return chr(ord(char) + 32)
else:
return char
flag = "".join([adjust_char(char) for char in flag])
print(f"EIS{{{flag}}}")
EIS{wadx_tdgk_aihc_ihkn_pjlm}