首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python 学习手册
Python Cookbook
Python 基础教程
Python Sites
PyPI - Python Package Index
http://www.simple-is-better.com/
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
V2EX  ›  Python

python3 AES ECB 模式解密后,解密后的数据尾部总是会有一些乱码,代码有些 low 请见谅

  •  
  •   qizheshang · 93 天前 · 987 次点击
    这是一个创建于 93 天前的主题,其中的信息可能已经有所发展或是发生改变。

    from Crypto.Cipher import AES from binascii import b2a_hex, a2b_hex

    #加密 def generateAES(key,text): bs = len(key) endode_text=text.encode() length=len(endode_text) PADDING = lambda s: s + (bs - length % bs) * chr(bs - length % bs) entext = PADDING(text) aes = AES.new(str.encode(key), AES.MODE_ECB) aes_text=str(b2a_hex(aes.encrypt(str.encode(entext))), encoding='utf-8') aes_text=aes_text.upper() return aes_text

    #解密 def ungenerateAES(key,text): bs = len(key) endode_text=text.encode() length=len(endode_text) PADDING = lambda s: s + (bs - length % bs) * chr(bs - length % bs) entext = PADDING(text) aes = AES.new(str.encode(key), AES.MODE_ECB) aes_text=aes.decrypt(a2b_hex(text)).decode() return aes_text

    key='ABaRZKqrsdF7Nmfg' text='E83A56F6BCF88E5BD3600C398E39EAAFA91DBA24807B73F7B76FF1E180CEA14DAED6A43F93'
    'EECE03B3017BD17859121A5A91AC7E9FFD8074B3A2E8FBF055B2F192730338E1225E8CB189'
    'CC65693BE53430D41E6100EA40E6ECD54E081AEE8A2648B1404901044C50503198C2D3A57661'

    plaintext=ungenerateAES(key,text) print("解密:",plaintext)

    解密: {"responseCode":"0000","quickAuthId":1907195371873309,"responseMsg":"发送纯签约短信成功"}

    12 回复  |  直到 2019-07-23 15:39:11 +08:00
        1
    qwerthhusn   93 天前   ♥ 1
    你最起码,把代码放到代码块里面啊
    而且 Python 还是那种强依赖缩进的语言,你堆成一行
    ```
    code here
    ```
        2
    chenxinqun   93 天前
    这代码还真看不懂...
        3
    lcdtyph   93 天前
    乱码是加密之前你自己加的 padding,解密之后你得自己去掉。
        4
    ytmsdy   93 天前
    大兄弟,贴 python 代码好歹带个缩进啊。要不然看个锤子啊!
        5
    reus   93 天前
    那是 padding
    ECB 不安全,建议直接 GCM
        6
    qizheshang   93 天前
    @qwerthhusn V2EX 排版问题 我的锅
        7
    qizheshang   93 天前
    @ytmsdy 擦 没在意我的锅
        8
    qwerthhusn   93 天前
    @qizheshang https://pycryptodome.readthedocs.io/en/latest/src/util/util.html#crypto-util-padding-module 它的工具包里面有自带的 Padding,文档里面也有 AES 加 padding 的描述,可以参考下
        9
    zkqiang   90 天前   ♥ 1
    解密是要 unpad
    具体根据 Padding 的算法:
    NoPadding 填充是去除末尾的零字节码
    PKCS5Padding 填充是根据最后一位的字节码去除对应的位数
        10
    zkqiang   90 天前
    仔细看了一下代码,是你解密里 PADDING 这个 lambda 写错了,应该正好是加密里的逆过程
        11
    qizheshang   89 天前
    @zkqiang 感谢大佬给我的启发,现在解决了,解密模块去掉 padding,加上这行代码就可以了 aes_text = re.compile('[\\x00-\\x08\\x0b-\\x0c\\x0e-\\x1f\n\r\t]').sub('', aes_text.decode())
        12
    qizheshang   89 天前
    @reus 公司加密模块,我只是逆向写段代码批量做些数据
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   4241 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 32ms · UTC 02:42 · PVG 10:42 · LAX 19:42 · JFK 22:42
    ♥ Do have faith in what you're doing.