+
80
-

python如何使用SM2加密?

python如何使用SM2加密?


网友回复

+
0
-

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算法。如果您有任何其他问题,欢迎在评论中提出,我会及时回复。
我知道答案,我要回答