美文网首页
python des加解密

python des加解密

作者: brucewu_2008 | 来源:发表于2018-05-03 12:16 被阅读0次

    在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)
    

    相关文章

      网友评论

          本文标题:python des加解密

          本文链接:https://www.haomeiwen.com/subject/ixpkrftx.html