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)

你可能感兴趣的:(python des加解密)