python des加解密

在python中进行des加解密处理,一般推荐的库例如 pyDes,pycrypto,如何使用网上有很多的介绍。以pyDes为例,在使用的过程中,碰到key的长度不符的情况。 例如,如下函数,我要通过secret_key为s进行des解密,会报出"Invalid DES key size. Key must be exactly 8 bytes long."的错误

def desdecode(secret_key,s):
    cipherX = DES.new(secret_key, DES.MODE_ECB)
    y = cipherX.decrypt(s)

跟进pyDes.py的源码去看一下。

# Initialisation
    def __init__(self, key, mode=ECB, IV=None, pad=None, padmode=PAD_NORMAL):
        # Sanity checking of arguments.
        if len(key) != 8:
            raise ValueError("Invalid DES key size. Key must be exactly 8 bytes long.")
        _baseDes.__init__(self, mode, IV, pad, padmode)
        self.key_size = 8

        self.L = []
        self.R = []
        self.Kn = [ [0] * 48 ] * 16 # 16 48-bit keys (K1 - K16)
        self.final = []

        self.setKey(key)

这里会发现这里的key要求长度是8, 但我这个密文是服务端发送过来的,且是用16位的key加密的。那么,该如何处理呢?

经过一段时间摸索,看到pyDes.py的的setKey函数,是否可以变通一下? 尝试了一下这样,就能正常解密了。

    cipherX = pyDes.des('        ')
    cipherX.setKey(secret_key)
    y=cipherX.decrypt(s)
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文主要介绍移动端的加解密算法的分类、其优缺点特性及应用,帮助读者由浅入深地了解和选择加解密算法。文中会包含算法的...
    苹果粉阅读 13,954评论 5 29
  • 首先罗列一些知识点: 1.加密算法通常分为对称性加密算法和非对称性加密算法:对于对称性加密算法,信息接收双方都需事...
    JonesCxy阅读 5,278评论 2 4
  • 清晨,被鸟叫声唤醒,我来到屋外。 漫步在老家的院子里,耳边是叽叽喳喳的鸟叫声,欢快而婉转。空气很清新,风有点凉,幸...
    绽蕊向阳阅读 3,576评论 0 1
  • 长沙并没有沙 只有那不灭的火炬和迷人的她 我从河西走到解放西 从酒吧走到 KTV 我曾在醉过无数个黎明 也曾见过无...
    Elope_小私奔阅读 2,047评论 0 2
  • 陶渊明说:好读书,不求甚解。 有位老师曾说:最幸福的事是毫无目的地读书。他大概不会想到,这句话令...
    折梅阅读 2,944评论 8 4