import binascii
#导入国密算法sm4包
from gmssl import sm4
def sm4_encode(key, data):
"""
国密sm4加密
:param key: 密钥
:param data: 原始数据
:return: 密文hex
"""
sm4Alg = sm4.CryptSM4() # 实例化sm4
sm4Alg.set_key(key.encode(), sm4.SM4_ENCRYPT) # 设置密钥
dateStr = str(data)
print("明文:", dateStr);
enRes = sm4Alg.crypt_ecb(dateStr.encode()) # 开始加密,bytes类型,ecb模式
enHexStr = enRes.hex()
print("密文:", enHexStr);
return enHexStr # 返回十六进制值
# return encrypt_value.hex()
def sm4_decode(key, data):
"""
国密sm4解密
:param key: 密钥
:param data: 密文数据
:return: 明文hex
"""
sm4Alg = sm4.CryptSM4() # 实例化sm4
sm4Alg.set_key(key.encode(), sm4.SM4_DECRYPT) # 设置密钥
deRes = sm4Alg.crypt_ecb(bytes.fromhex(data)) # 开始解密。十六进制类型,ecb模式
deHexStr = deRes.decode()
print("解密后明文:", deRes);
print("解密后明文hex:", deHexStr);
return deHexStr
#测试函数
def test():
key = "E1A90FB64DDE12AE";
strData = "12345abcde"
enHexRes = sm4_encode(key,strData);
print("解密测试===",enHexRes);
sm4_decode(key,enHexRes);
# main
if __name__ == '__main__':
print("main begin");
test();
————————————————
版权声明:本文为CSDN博主「liranke」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/liranke/article/details/127796991