加密算法AES和RC4的效率

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

测试环境:window10

测试语言:python3.8

先上结论:

只是对一个文件的单次加解密的话,使用RC4效率会比较高。至少相对于2M的文件而言是这样的。

拿了一个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")

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值