python如何使用SM2加密?
网友回复
SM2是国密算法的一种,用于 replacements 加密和数字签名。在Python中可以使用cryptography库来实现SM2加密。
这里是一个简单的SM2加密和解密示例:
from cryptography.hazmat.primitives.asymmetric import sm2 from cryptography.hazmat.primitives import serialization # 生成SM2密钥对 private_key = sm2.generate_private_key() public_key = private_key.public_key() # 序列化密钥 private_pem = private_key.private_bytes( encoding=serialization.Encoding.PEM, format=serialization.PrivateFormat.TraditionalOpenSSL, encryption_algorithm=serialization.NoEncryption() ) public_pem = public_key.public_bytes( encoding=serialization.Encoding.PEM, format=serialization.PublicFormat.SubjectPublicKeyInfo ) # 加密 message = b"Hello, world!" ciphertext = public_key.encrypt( message, sm2.SM2_CIPHERTEXT_SIZE ) # 解密 original_message = private_key.decrypt( ciphertext, sm2.SM2_CIPHERTEXT_SIZE ) print(original_message) # b'Hello, world!'
这个示例中,我们生成一个SM2密钥对,分别序列化成PEM格式的私钥和公钥。
然后使用公钥加密明文"Hello, world!",得到密文。
最后使用私钥解密密文,还原出原始的明文。
SM2算法还可以用于数字签名,验证签名等操作。cryptography库提供了完整的SM2算法支持,我们可以很容易地在Python项目中集成SM2的功能。
希望这个简单示例能帮助您了解如何在Python中使用SM2算法。如果您有任何其他问题,欢迎在评论中提出,我会及时回复。