BUUCTF Reverse [GWCTF 2019]pyre WriteUp

pyre-WP

首先发现是pyc文件,使用在线工具进行反编译,得到源码

#!/usr/bin/env python
# visit http://tool.lu/pyc/ for more information
print "Welcome to Re World!"
print "Your input1 is your flag~"
l = len(input1)
for i in range(l):
    num = ((input1[i] + i) % 128 + 128) % 128
    code += num #字符串拼接
for i in range(l - 1):
    code[i] = code[i] ^ code[i + 1]
print code
code = [
    "\x1f",
    "\x12",
    "\x1d",
    "(",
    "0",
    "4",
    "\x01",
    "\x06",
    "\x14",
    "4",
    ",",
    "\x1b",
    "U",
    "?",
    "o",
    "6",
    "*",
    ":",
    "\x01",
    "D",
    ";",
    "%",
    "\x13",
]

对此源码进行分析发现,其中要求输入的应该是flag,输入后将其与自己的位数相加,对128求余的目的是确保其在ASCII中,然后在将每一位与下一位进行异或,注意,最后一位未进行运算。

逆向分析,异或之后,我们有运算完的值,要求之前的值就将其与那个数字再进行一次异或(a0=a,aa=0,abb=a)但是特别注意,要是逆序的才行,同时注意,a=(b-c)%d的逆运算为b=(a+c)%d,最终写出解密脚本。

code = [0x1f,0x12,0x1d,0x28,0x30,0x34,0x01,0x06,0x14,0x34,0x2C,0x1b,0x55,0x3F,0x6f,0x36,0x2a,0x3a,0x01,0x44,0x3b,0x25,0x13]

a = len(code)
for i in range(a-2,-1,-1): #此处注意一点,range是包前不包后
    code[i] = code[i] ^ code[i + 1]

for i in range(a):
    print(chr((code[i] - i) % 128),end='')

最终结果GWHT{Just_Re_1s_Ha66y!},但是要提交flag{Just_Re_1s_Ha66y!}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

PlumpBoy

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

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

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

打赏作者

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

抵扣说明:

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

余额充值