php des pkcs5padding,python实现PKCS5Padding

python实现PKCS5Padding

python实现PKCS5Padding

2008-09-21

请参考

ssl-3-padding-mode

php的加密函数库

DES加密的Python和PHP实现

在PKCS5Padding中,明确定义Block的大小是8位

而在PKCS7Padding定义中,对于块的大小是不确定的,可以在1-255之间

PKCS #7 填充字符串由一个字节序列组成,每个字节填充该字节序列的长度。

假定块长度为 8,数据长度为 9,

数据: FF FF FF FF FF FF FF FF FF

PKCS7 填充: FF FF FF FF FF FF FF FF FF 07 07 07 07 07 07 07

def nrPadBytes(blocksize, size):

'Return number of required pad bytes for block of size.'

if not (0 < blocksize < 255):

raise Error('blocksize must be between 0 and 255')

return blocksize - (size % blocksize)

def appendPadding(blocksize, s):

'''Append rfc 1423 padding to string.

RFC 1423 algorithm adds 1 up to blocksize padding bytes to string s. Each

padding byte contains the number of padding bytes.

'''

n = nrPadBytes(blocksize, len(s))

return s + (chr(n) * n)

def removePadding(blocksize, s):

'Remove rfc 1423 padding from string.'

n = ord(s[-1]) # last byte contains number of padding bytes

if n > blocksize or n > len(s):

raise Error('invalid padding')

return s[:-n]

PKCS5的另一种

pad_len = 8 - (len(data) % self.block_size)

if _pythonMajorVersion < 3:

data += pad_len * chr(pad_len)

else:

data += bytes([pad_len] * pad_len)

if _pythonMajorVersion < 3:

pad_len = ord(data[-1])

else:

pad_len = data[-1]

data = data[:-pad_len]

第3种

pad = lambda s: s + (BS - len(s) % BS) * chr(BS - len(s) % BS)

unpad = lambda s : s[0:-ord(s[-1])]

tags: PKCS5

发表在 Python, 软件逆向工程 作者 zhiwei

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值