栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

加密算法AES和RC4的效率

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

加密算法AES和RC4的效率

网上有很多算法的理论说明,我也就不重复了,直接看结果。

测试环境:window10

测试语言:python3.8

拿了一个2M左右的文件进行加解密测试。最终的测试效率如下:

算法10000次1000次1次
RC4-加密53.3s5.33s5.98ms
RC4-解密53.1s5.32s5.98ms
AEs-CBC-加密1min1s6.26s6.95ms
AEs-CBC-解密53.9s5.48s5.98ms
AEs-ECB-加密29.8s2.91s6.98ms
AEs-ECB-解密29.6s2.85s5.96ms

下面是RC4算法:

from Crypto.Cipher import ARC4


# 使用rc4加密
def _rc4_encrypt(c_content: bytes) -> bytes:
    p_rc4_object = ARC4.new(b"XXXXXXXXXXXX")
    c_encrypt_data = p_rc4_object.encrypt(c_content)
    return c_encrypt_data


# rc4解密代码内容
def _get_rc4_code(c_encrypt_data: bytes) -> bytes:
    p_py_rc4_obj = ARC4.new(b"XXXXXXXXXXXX")
    c_decrypt_data = p_py_rc4_obj.decrypt(c_encrypt_data)
    return c_decrypt_data

下面是AES-CBC算法:

# 补位的倍数
BLOCK_SIZE = 16
# CBC的16位偏移量
CBC_VECTOR = b"aaaaaaaaaaaaaaaa"
# 加密的密钥
ENCRYPT_KEY = b"bbbbbbbbbbbbbbbb"
# 加解密的模式
s_ciphor_mode = AES.MODE_CBC
# CBC加密
def _aes_cbc_encrypt(c_content: bytes) -> bytes:
    # 进行补位
    c_content = pad(c_content, BLOCK_SIZE)
    p_aes_cbc = AES.new(ENCRYPT_KEY, s_ciphor_mode, CBC_VECTOR)
    c_encrypt_content = p_aes_cbc.encrypt(c_content)
    return c_encrypt_content


# CBC解密
def _aes_cbc_decrypt(c_content: bytes) -> bytes:
    p_aes_cbc = AES.new(ENCRYPT_KEY, s_ciphor_mode, CBC_VECTOR)
    c_decrypt_content = p_aes_cbc.decrypt(c_content)
    # 清除之前补位的空值
    c_decrypt_content = c_decrypt_content.rstrip(b"x04")
    return c_decrypt_content

下面是AES-ECB算法:

# 加解密的模式
s_ciphor_mode = AES.MODE_ECB
# 加密
def _aes_encrypt(c_content: bytes) -> bytes:
    p_aes = AES.new(ENCRYPT_KEY, s_ciphor_mode)
    # 补位为 BLOCK_SIZE 的倍数
    c_content = pad(c_content, BLOCK_SIZE)
    c_encrypt_data = p_aes.encrypt(c_content)
    return c_encrypt_data


# 解密
def _aes_decrypt(c_encrypt_text: bytes) -> bytes:
    p_aes = AES.new(ENCRYPT_KEY, s_ciphor_mode)
    c_decrypt_data = p_aes.decrypt(c_encrypt_text)
    return c_decrypt_data.rstrip(b"x04")

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/355623.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号