[ctf.show.reverse] 来一个派森,好好学习天天向上

来一个派森

根据名字来看是一个编译成exe的python程序,

  1. 用py \tools\pyinstxtractor.py checkme.exe 将其解包,
  2. 然后将struct文件头部E3前的部分插入到checkme文件头部(恢复pyc头)
  3. 再将pyc文件反编译
#!/usr/bin/env python
# visit https://tool.lu/pyc/ for more information

def b58encode(tmp = None):
    tmp = list(map(ord, tmp))
    temp = tmp[0]
    base58 = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz'
    for i in range(len(tmp) - 1):
        temp = temp * 256 + tmp[i + 1]
    
    tmp = []
    while None:
        temp = temp // 58
        if temp == 0:
            break
        temp = ''
        for i in tmp:
            temp += base58[i]
        
    tmp = []
    for i in range(len(temp)):
        tmp.append(chr(ord(temp[i]) ^ i))
    
    check = ['A','5','q','O','g','q','d','\x7f','[','\x7f','s','{','G','A','x','`','D','@','K','c','-','c',' ','G','+','+','|','x','}','J','h','\\','l']
    if tmp == check:
        return 1

flag = input('\xe8\xbe\x93\xe5\x85\xa5flag\xef\xbc\x9a')
if b58encode(flag):
    print('you win')
else:
    print('try again')

这个程序就是把flag进行base58编码再作个异或,然后与check比较,所以将check异或后再base58解码即可

check = ['A','5','q','O','g','q','d','\x7f','[','\x7f','s','{','G','A','x','`','D','@','K','c','-','c',' ','G','+','+','|','x','}','J','h','\\','l']
a = ''
for i in range(len(check)):
    a+=chr(ord(check[i])^i)

print(a)
#A4sLctbxSvypKLvoTQYp9v6P32fcaWvCL
#ctfshow{zhe_bu_shi_flag}

好好学习天天向上

这个没着了,从网上看的flag

程序不算复杂就是一个查表然后累加,最后检查累加值,但这个值是累加值没法逆回。只能爆破

  for ( i = 0; i < 31; v4 += *(_QWORD *)&aA[8 * (int)(sub_140001140((unsigned __int8)byte_140014060[++i]) + v2)] )
  {
    if ( (int)sub_140001140((unsigned __int8)byte_140014060[i]) < 0 )
      goto LABEL_11;
    v2 = 17 * (sub_140001140((unsigned __int8)byte_140014060[i]) + 16 * i);
  }
  if ( v4 == 0x1C836D8E5C11047Fi64 && byte_140014060[31] == 125 )
    result = 1;

爆破程序

from pwn import *
tab = 'abdefglostuyp{}_'
aa = open('cStuday.exe', 'rb').read()[0x2400: 0x13400]
def deeptry(i, v4, s):
    if v4<0:
        return False
    if i==0:
        #print(i,hex(v4),s)
        if v4 == 0:
            print('-->'+s)
        return False
    for j in range(16):
        v2 = 17*(j + 16*i)
        p = 8 * (tab.index(s[0]) + v2)
        #print(hex(p))
        tmp = v4 - u64(aa[p:p+8])
        deeptry(i-1, tmp, tab[j]+s)

s = '}'
deeptry(31,0x1C836D8E5C11047F,s)

当然不会有什么结果,16^31这个数太大了。

网上看到这个值是猜的,因为key= abdefglostuyp{}_ 这里可以看到stu 结合题目名字"好好学习天天向上"猜到 flag{good_good_study_day_day_up} 验证一下没问题

s = 'flag{good_good_study_day_day_up}'
v4 = 0
for i in range(32-1):
    v2 = 17*(tab.index(s[i]) + 16*i)
    p = 8 * (tab.index(s[i+1]) + v2)
    v4 += u64(aa[p : p+8])

print(hex(v4))
if v4  == 0x1C836D8E5C11047F:
    print("ok:"+s)

好的,以下是一个简单的微信机器人框架的代码示例,你可以根据需要进行修改和优化: ```python import itchat from threading import Thread from queue import Queue class WechatBot: def __init__(self): self.msg_queue = Queue() self.bot = itchat.new_instance() self.bot.auto_login(hotReload=True) self.bot.run(blockThread=False) self.friend_list = self.bot.get_friends() def send_msg(self, msg, to_user): self.bot.send(msg, toUserName=to_user) def handle_msg(self, msg): from_user = msg['FromUserName'] msg_type = msg['Type'] if msg_type == 'Text': content = msg['Text'] self.msg_queue.put((from_user, content)) def listen(self): @self.bot.msg_register(['Text', 'Picture', 'Recording', 'Attachment', 'Video']) def receive_msg(msg): self.handle_msg(msg) def run(self): listen_thread = Thread(target=self.listen) listen_thread.start() while True: if not self.msg_queue.empty(): from_user, content = self.msg_queue.get() # 处理消息并回复 reply = self.reply(content, from_user) self.send_msg(reply, from_user) def reply(self, msg, from_user): # 实现具体的自动回复逻辑 return "这是机器人自动回复的消息。" if __name__ == '__main__': bot = WechatBot() bot.run() ``` 以上代码实现了一个基本的微信机器人框架,它能够监听用户发送的消息并将其加入消息队列,然后在主线程中不断从消息队列中读取消息并进行处理和回复。你可以根据需要修改 `reply` 函数来实现具体的自动回复逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值