CTF CRYPTO 密码学-3

简介: CTF CRYPTO 密码学-3

题目名称:反编译


题目描述:



分析


题目给出一个pyc后缀的文件,需要使用uncompyle6模块去还原成py文件


uncompyle6简介


uncompyle6 是一个 Python 反编译器,它能够将 Python 字节码(.pyc 文件)转换回源代码(.py 文件)。


解题过程:


Step1:下载uncompyle6包

pip install uncompyle6


注意 版本问题


uncompyle6默认只支持3.8及以下版本


如何修改?(我这里是python3.11.3)


Python311\Lib\site-packages\uncompyle6\bin\uncompile.py



修改位置:Python311\Lib\site-packages\xdis\magics.py


Step2:在uncompyle6.exe目录下运行反编译命令


Step3:编写逆算法


生成的py文件内容如下:

# uncompyle6 version 3.7.4
# Python bytecode 2.7 (62211)
# Decompiled from: Python 3.11.3 (tags/v3.11.3:f3909b8, Apr  4 2023, 23:49:59) [MSC v.1934 64 bit (AMD64)]
# Embedded file name: b'C:\\Users\\CD\\Desktop\\\xb7\xb4\xb1\xe0\xd2\xeb\\crypto11.py'
# Compiled at: 2019-11-24 10:36:35
import base64
def encode1(ans):
    s = ''
    for i in ans:
        x = ord(i) ^ 18
        x = x + 19
        s += chr(x)
    return s
def encode2(ans):
    s = ''
    for i in ans:
        x = ord(i) + 66
        x = x ^ 32
        s += chr(x)
    return s
def encode3(ans):
    return base64.b16encode(ans)
flag = ' '
print 'Please Input your flag:'
flag = raw_input()
final = 'E9F3E8EA9EECE859E5555BA0A05F555A555CEBE955EC59E5EC5AECE858E9ECE555EB5FE6E8E4'
if encode3(encode2(encode1(flag))) == final:
    print 'correct'
else:
    print 'wrong'


逆运算脚本如下:

import base64
def decode2(ans):
    s = ''
    for i in ans:
        j=ord(i)
        x=j ^ 32
        x-=66
        s += chr(x)
    return s
def decode1(ans):
    s = ''
    for i in ans:
        j=ord(i)
        x=j-19
        x=x^18
        s += chr(x)
    return s
final = 'E9F3E8EA9EECE859E5555BA0A05F555A555CEBE955EC59E5EC5AECE858E9ECE555EB5FE6E8E4'
s = base64.b16decode(final)
s = decode1(decode2(s))
print s


相关资源:


链接:https://pan.baidu.com/s/13S5xdwEvsb1H0nLTlyzMAA

提取码:25fq

目录
相关文章
|
6月前
|
数据安全/隐私保护 对象存储
CTF CRYPTO 密码学-4
CTF CRYPTO 密码学-4
82 1
|
6月前
|
数据安全/隐私保护
CTF CRYPTO 密码学-2
CTF CRYPTO 密码学-2
133 0
|
6月前
|
存储 Linux 网络安全
CTF CRYPTO 密码学-1
CTF CRYPTO 密码学-1
97 0
|
6月前
|
算法 安全 关系型数据库
密码学系列之七:数字签名
密码学系列之七:数字签名
|
Rust 算法 安全
【密码学】一文读懂HMAC
本文将来聊一聊基于哈希函数的消息认证码,在此之前,先来科普一下什么是 「消息认证码」 (MAC), 先来看一个简单的栗子
1670 0
【密码学】一文读懂HMAC
|
6月前
|
网络安全
蓝桥杯-网络安全-练习题-crypto-rsa
蓝桥杯-网络安全-练习题-crypto-rsa
蓝桥杯-网络安全-练习题-crypto-rsa
|
3月前
|
SQL 安全 算法
BugKu CTF(Crypto):MaybeEasyRSA & easy_crypto & 黄道十二宫 & 给你私钥吧
BugKu CTF(Crypto):MaybeEasyRSA & easy_crypto & 黄道十二宫 & 给你私钥吧
|
3月前
|
SQL 安全 算法
BugKu CTF(Crypto):Caesar cipher & 抄错的字符 & /.- & 聪明的小羊 & ok
BugKu CTF(Crypto):Caesar cipher & 抄错的字符 & /.- & 聪明的小羊 & ok
|
4月前
|
算法 安全 网络安全
网络安全&密码学—python中的各种加密算法
数据加密是一种保护数据安全的技术,通过将数据(明文)转换为不易被未经授权的人理解的形式(密文),以防止数据泄露、篡改或滥用。加密后的数据(密文)可以通过解密过程恢复成原始数据(明文)。数据加密的核心是密码学,它是研究密码系统或通信安全的一门学科,包括密码编码学和密码分析学。
|
算法 数据安全/隐私保护
【密码学】一文读懂SHA-1
SHA-1(Secure Hash Algorithm 1)是一种密码散列函数,美国国家安全局设计,并由美国国家标准技术研究所(NIST)发布为联邦资料处理标准(FIPS)。SHA-1可以生成一个被称为消息摘要的160位(20字节)散列值,散列值通常的呈现形式为40个十六进制数。
1209 1
【密码学】一文读懂SHA-1