栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用PyCrypto AES进行Python加密

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用PyCrypto AES进行Python加密

老实说,字符 “ n n n n n n n n n n n” 在我看来并不那么随意。;-)

您正在CBC模式下使用AES。这就要求明文和密文的长度始终为16字节的倍数。使用显示的代码,您实际上应该看到

data
传递给的异常
encrypt()
不满足该条件时引发了异常。看起来您已经在输入的内容中添加了足够的换行符(
’ n’ ,直到明文碰巧对齐为止。

除此之外,还有两种解决对齐问题的常用方法:

  1. 从CBC(

    AES.MODE_CBC
    )切换到CFB(
    AES.MODE_CFB
    )。
    segment_size
    使用PyCrypto使用的默认值,您将对明文和密文长度没有任何限制。

  2. 保留CBC并使用类似PKCS#7的填充方案,即:

    • 在对
      X
      字节的明文进行加密之前,请向后追加达到下一个16字节边界所需的尽可能多的字节。所有填充字节都具有相同的值:您要添加的字节数:
          length = 16 - (len(data) % 16)

      data += bytes([length])*length

这就是Python 3风格。在Python 2中,您将具有:

 length = 16 - (len(data) % 16)    data += chr(length)*length* 解密后,从纯文本的后面删除与填充指示的一样多的字节: data = data[:-data[-1]]

即使我了解您的情况,这只是一个课堂练习,但我想指出的是,没有任何形式的身份验证(例如,MAC)发送数据是不安全的。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/638443.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号