数字信封模块代码,python实现

from gmssl import sm2, sm3, sm4, func


# 随机生成sm4密钥
def generate_sm4_key():
    return func.random_hex(16)  # SM4密钥长度为128位(16字节)


# 使用SM4加密明文
def sm4_encode(key, data):
    sm4Alg = sm4.CryptSM4()  # 实例化sm4
    sm4Alg.set_key(key.encode(), sm4.SM4_ENCRYPT)  # 设置密钥
    enRes = sm4Alg.crypt_ecb(data.encode())  # 开始加密,bytes类型,ecb模式
    enHexStr = enRes.hex()
    return enHexStr  # 返回十六进制值


# 使用sm3生成消息摘要
def sm3_message_digest(data):
    digest = sm3.sm3_hash(func.bytes_to_list(data.encode()))
    # print(digest)
    return digest


# 生成SM2密钥对
def generate_sm2_key():
    sm2_crypt = sm2.CryptSM2(private_key='', public_key='')
    private_key, public_key = sm2.CryptSM2.generate_keypair(sm2_crypt)
    return private_key, public_key


# 使用接受方sm2公钥对sm4密钥进行加密
def public_sm2_encrypt(data, public_key):
    sm2_crypt = sm2.CryptSM2(public_key=public_key, private_key='')
    enc_data = sm2_crypt.encr
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值