暂时停更,一堆数据统计与分析的工作要做
拖到ida,一键F5 main函数,然后跟入main数中,最终来到如下函数,
函数大概意思就是读入flag,然后flag经过一个函数转化,再通过for循环再做一次变化,最终变化的字符等于str2
那么str2如下:
那么先for循环到原来的字符
import base64
st = "e3nifIH9b_C@n@dH"
st1 = ""
for i in range(0,len(st)):
st1 += chr(ord(st[i])-i)
print(st1)
此时离flag还差一个函数,进去查看,属于一个64位数组的变化了
我先猜是base64,试试base64看看
试了下,果然成了
import base64
st = "e3nifIH9b_C@n@dH"
st1 = ""
for i in range(0,len(st)):
st1 += chr(ord(st[i])-i)
print(st1)
st2 = "e2lfbDB2ZV95b3V9"
st3 = base64.b64decode(st2)
print(st3)
当然有兴趣的可以把base64原理实现一遍,那么base64系列魔改的算法也不怕了