Python 官方文档:入门教程 => 点击学习
本篇利用python中的gmssl库进行sm4算法的加解密演示。 国密算法sm4特点: 密钥长度:16bytes(128bits)分组长度和密钥长度均为128bits;是对称加密算法;分为ecb模式和
本篇利用python中的gmssl库进行sm4算法的加解密演示。
Python提供了sm4算法相关的包,可以用导入gmssl包,利用这个包提供的sm4算法进行数据的加解密。
#导入国密算法sm4包from gmssl import sm4
实例化:sm4.CryptSM4()
设置加密密钥key:set_key(key, sm4.SM4_ENCRYPT) # 设置密钥
加密:crypt_ecb(plaintext)
设置解密密钥key:set_key(key, sm4.SM4_DECRYPT) # 设置密钥
解密:crypt_ecb(chipertext)
import binascii#导入国密算法sm4包from gmssl import sm4def 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();
测试结果:
% python sm4_t3.py
main begin
明文: 12345abcde
密文: 39b1d120849884da97b57830de18fb75
解密测试=== 39b1d120849884da97b57830de18fb75
解密后明文: b’12345abcde’
解密后明文hex: 12345abcde
来源地址:https://blog.csdn.net/liranke/article/details/127796991
--结束END--
本文标题: 国密算法:利用python进行sm4算法的加解密,对称密钥
本文链接: https://lsjlt.com/news/390562.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0