python实现sm4,ecb模式加密

该代码示例展示了如何用Python的gmssl库实现SM4加密和解密,特别是针对十六进制字符串的处理。MY_SM4类包含了加密和解密方法,以及将字符串转换为十六进制的辅助函数。在主函数中,给出了加密测试的例子。
摘要由CSDN通过智能技术生成

需求

python实现输入十六进制字符串key和待加密的值,返回加密后的十六进制值
关键在于对十六进制字符串key的处理

from gmssl.sm4 import CryptSM4, SM4_ENCRYPT, SM4_DECRYPT
import binascii


class MY_SM4(object):
    """
    国密sm4加解密
    """

    def __init__(self):
        self.crypt_sm4 = CryptSM4()

    @staticmethod
    def str_to_hex_str(hex_str):
        """
        字符串转hex
        :param hex_str:
        :return:
        """
        hex_data = hex_str.encode('utf-8')
        str_bin = binascii.unhexlify(hex_data)
        return str_bin.decode('utf-8')

    def encrypt(self, encrypt_key, value):
        """
        国密sm4加密
        :param encrypt_key:
        :param value:
        :return: sm4加密后的hex值
        """
        crypt_sm4 = self.crypt_sm4
        # crypt_sm4.set_key(encrypt_key.encode(), SM4_ENCRYPT)  # encrypt_key: 字节类型
        crypt_sm4.set_key(encrypt_key, SM4_ENCRYPT)
        encrypt_value = crypt_sm4.crypt_ecb(value.encode())  # bytes类型
        return encrypt_value.hex()

    def decrypt(self, decrypt_key, encrypt_value):
        """
        国密sm4解密
        :param decrypt_key: sm4加密key
        :param encrypt_value: 待解密的hex值
        :return:
        """
        crypt_sm4 = self.crypt_sm4
        # crypt_sm4.set_key(decrypt_key.encode(), SM4_DECRYPT)  # decrypt_key: 字节类型
        crypt_sm4.set_key(decrypt_key, SM4_DECRYPT)
        d_value = crypt_sm4.crypt_ecb(bytes.fromhex(encrypt_value))  # bytes类型
        return self.str_to_hex_str(d_value.hex())


if __name__ == "__main__":
    sm4_ = MY_SM4()
    key = "0CC5D57BF7D4F3B4F7BB7700572C25C4"
    keys = [int(key[2*i:2*i+2], 16) for i in range(16)]
    print(keys)
    key = bytes(b % 256 for b in keys)
    # # 加密测试
    encrypt_params = '13508081234'
    result1 = sm4_.encrypt(key, encrypt_params)
    print('result1:', result1)
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

pchaoda

感谢支持~~~~~~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值