ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

easychallenge

2021-10-30 09:07:05  阅读:176  来源: 互联网

标签:easychallenge base64 36 chr flag ans print


easychallenge(来源:攻防世界)

1.关卡描述



 2.解题步骤

分析:

 使用工具进行反编译:

# Embedded file name: ans.py
import base64

def encode1(ans):
    s = ''
    for i in ans:
        x = ord(i) ^ 36
        x = x + 25
        s += chr(x)

    return s


def encode2(ans):
    s = ''
    for i in ans:
        x = ord(i) + 36
        x = x ^ 36
        s += chr(x)

    return s

def encode3(ans):
    return base64.b32encode(ans)

flag = ' '
print 'Please Input your flag:'
flag = raw_input()
final = 'UC7KOWVXWVNKNIC2XCXKHKK2W5NLBKNOUOSK3LNNVWW3E==='
if encode3(encode2(encode1(flag))) == final:
    print 'correct'
else:
    print 'wrong'

我们只要输入的flag值等于final的值就可以了,也就是说我们需要反向解密:

python函数嵌套中,先执行里面的,在执行外面的

异或加密:

异或运算具有可逆性。

即:若a^b=c,则有b^c=a (a,b,c分别表示0或1)

在二进制中:

1 XOR 0=1

0 XOR 1=1

1 XOR 1=0

0 XOR 0=0

可以看出若两个数相同取0,不同取1。

我们通过反顺序异或来反编译出flag

先处理 encode3---》 encode2------》 encode1

import base64
s="UC7KOWVXWVNKNIC2XCXKHKK2W5NLBKNOUOSK3LNNVWW3E==="
s=base64.b32decode(s)
#print s
m = ''
for i in s:
   x = ord(i) ^ 36
   x = x - 36 #反过来处理
   m+= chr(x)
h = ''
for i in m:
   x = ord(i) - 25 #反过来处理
   x = x ^ 36
   h+= chr(x)
print h
cyberpeace{interestinghhhhh}

或者:

标签:easychallenge,base64,36,chr,flag,ans,print
来源: https://blog.csdn.net/weixin_39934520/article/details/121046324

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有