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