python实现PKCS5Padding
来源:互联网 发布:高清网络摄像机怎么用 编辑:程序博客网 时间:2024/05/22 01:59
在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])]
0 0
- python实现PKCS5Padding
- golang中DES/ECB/PKCS5Padding的实现
- AES-CBC-PKCS5Padding加密算法Java实现
- AES-CBC-PKCS5Padding加密算法Java实现
- C#, Java, PHP, Python和Javascript几种语言的AES加密解密实现【多种语言AES/CBC/PKCS5Padding通用加解密数据】
- java实现基于PKCS5Padding填充方式的AES加解密
- Java与C/C++通用的“AES/ECB/PKCS5Padding”实现
- PKCS7Padding & PKCS5Padding
- AES PKCS5Padding
- AES-256-CBC-PKCS5Padding用c语言实现,并支持Android手机的调用
- 和java的DES/ECB/PKCS5Padding相同的objc实现方式
- php中实现3DES算法(ECB加密模式PKCS5Padding填充)
- AES/ECB/PKCS5Padding
- PKCS5Padding 和 PKCS7Padding
- DES/ECB/CBC/PKCS5Padding
- android加密DESede/CBC/PKCS5Padding
- android加密DESede/CBC/PKCS5Padding
- PKCS5Padding与PKCS7Padding的区别
- STM32F103/107 移植Freemodbus RTU
- Yii获取当前url和域名
- 第十三周阅读程序二
- CTO讲堂摘录
- 第14周项目1-小玩文件
- python实现PKCS5Padding
- 第14周 项目二-用文件保存学生名单
- C语言入门教程13-数组-批量数据存储
- Magento根据产品SKU查询产品库存状态
- 第十四周 阅读项目 C++标准输入输出
- 在Linux中用chattr和lsattr命令管理文件和目录属性
- 第14周项目1-小玩文件(2)
- myeclipse 安装SVN插件
- 第十四周阅读程序三