相关依赖:

  1. gmssl==3.2.2
  2. pycryptodome == 3.9.7

相关实现

import abc
import base64from Crypto.Hash import SHA256
from Crypto.PublicKey import RSA
from Crypto.Signature import PKCS1_v1_5
from gmssl import sm2class BaseSignatureUtil(metaclass=abc.ABCMeta):@abc.abstractmethoddef signature(self, *args, **kwargs): pass@abc.abstractmethoddef verify_signature(self, *args, **kwargs): passclass RsaWithSha256Util(BaseSignatureUtil):@staticmethoddef signature(sign_data: str, private_key: str) -> str:rsa_key = RSA.importKey(private_key)signer = PKCS1_v1_5.new(rsa_key)_rand_hash = SHA256.new()_rand_hash.update(sign_data.encode('utf-8'))signature = signer.sign(_rand_hash)return base64.b64encode(signature).decode('utf-8')@staticmethoddef verify_signature(verify_data: str, signature: str, public_key: str):rsa_key = RSA.importKey(public_key)signer = PKCS1_v1_5.new(rsa_key)_rand_hash = SHA256.new()_rand_hash.update(verify_data.encode('utf-8'))return signer.verify(_rand_hash, base64.b64decode(signature))class Sm3WithSm2Util(BaseSignatureUtil):"""Sm3WithSm2签名及验签实现"""@staticmethoddef signature(sign_data: str, private_key: str, public_key: str):"""此处签名需要公钥:param sign_data::param private_key: 私钥:param public_key: 公钥:return:"""crypt = sm2.CryptSM2(private_key=private_key, public_key=public_key, mode=1, asn1=True)sign_str = crypt.sign_with_sm3(bytes(sign_data, encoding="utf8"))b64 = base64.b64encode(bytes.fromhex(sign_str)).decode()return b64@staticmethoddef verify_signature(verify_data: str, signature: str, public_key: str):""":param public_key::param verify_data::param signature::return:"""crypt = sm2.CryptSM2(private_key="", public_key=public_key, mode=1, asn1=True)return crypt.verify_with_sm3(base64.b64decode(signature).hex(), bytes(verify_data, encoding="utf8"))

使用

if __name__ == '__main__':rsa_pri_key = """-----BEGIN PRIVATE KEY-----
MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQCR2eBgYkRLPZgs
OFf2/81o5i69/S2rjGic/YW7Clm1mokiYZ1YLDEHH2c7tdvXJrmfLavc4ngruX4y
Uddn9A2+Ts+B5YbsbRrzOJ9ok6CA0MaVpAYejmaT/bq3e2jBY2rwI7NBzfx7c1H/
gRNY2kMTGK6l2aI4fg8jxCLt+5jOU9UbvEmwd4VNBcqfUpb9VTukdCfXt9p3jtLB
ej2bc2CQwReuv8FldhuGzDgHLvRRplXeGQ1i2OwvCguJiZH8mCq4/18336Mf0Xoc
bG7BmQYATPf+0OOkb1fJ9vDTtgLDB0T1BxiajoUNP5F4RLWer0eIDnF6iO46zwjC
czasKs3XAgMBAAECggEAEDog7ChSt9pRAW59XvZD6M1fWvT9rU3wX7MXO2Gh7IIW
itQ4eNRl2giE6FBJ9syQr2SZ7/fkbdzz7O5NHHw7QTasgKPEWK6k5nWgyrZOD7bq
uUBoC+NFB2cd7IcW9xk0DyaxrXsZAbUpZNd8CxExkEDZQYuOsGFaFt0eE8M/04i2
L9QPB3WQ3lN+sK8q9AfTBK3yv8MkGI8+00Ihp9TLZ1XqhtvlJSxKs6vLFAcH8rzP
ZKsSnqM7KGVlv5azkIeFeNLWHIzjepjA3V4ncnbu4nOBiuNGlcNh9++ELmHF+fNk
EmGO4u+GTgfuaECFtjdeq+DUH8JJ0dPXOEMhGX8p2QKBgQC5yxa3CodwW832dQ+u
pQaN3J7pZfgUrHK1idGSyGxuehEU+wyjSSwOC1eUGaP4dmj6azmvz5Ng4xPa7Ew3
TemNz7HGVnx8L+YMYa+cJHEfaWEvByin5nnPgy79Fy6aO49uK1egFGFNSPV7i4Sd
nnGt/8ye+g65uS2MwSxAN3V/WQKBgQDI9u8G0xFNI3tg7glFTr9yy/WihCZ495BZ
Bq7MAQWsaNUOR0Rh6/+gDDG2j0m3Yjnk9JFXpuctZGnVyWi1fBGjjW25e8NiyBjz
BJbpPNrkxJWpdeG51gKaOUgz2YfnooHKrt/3Cn1LO6KrNBPZMw7++NpWWh+aRE6A
cVWFOUbArwKBgHYLQdBkQS8zNQYc1CzrLuHdRZ4XKmrAMlWDTgNLkhETP10sMJhi
OjpmHGu9ar/HQ+WvUMSSRxoszIWw0q/ksbpnNpVEh+1DZY+CVVgIk1MY2iVOEBe1
SLl+qNEm9HYL15JwuUi9CiFXdJjdSRH4BFRADRsI12hK7lTauynF0sJpAoGBAIt/
fWRLVxMoshgSo7TMePCCy7tH6DzH/BcQIH3Tp9CJ5HrI1Zrzarn6PPfwdscpE+7u
JYWmgYpszVptOJXhzYyuO6ApXPNQ2qC2atr0Ny3dl9XN0iZhe+T6Jjh3o3MSxu2e
fjDJwzdZ6gzVVYHLg3lR3J1cadt31tYp1adonshZAoGAWTgi+QE1ts0HwztCw2CV
3AeKB6wZNfFNYEE4bwZhwWUQMOEjnlwh9IHwjMh5POyFD5BR/YAgihW3/u052/9O
1w7I18QvqjwSyPRVMXhItT51P5QNsugRRcsCNTHvWdozjgKuIP5pLTK+nwE7PPl3
UUNybmttjqJCyfndIOUOVlQ=
-----END PRIVATE KEY-----"""rsa_pub_key = """-----BEGIN PUBLIC KEY-----
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAkdngYGJESz2YLDhX9v/N
aOYuvf0tq4xonP2FuwpZtZqJImGdWCwxBx9nO7Xb1ya5ny2r3OJ4K7l+MlHXZ/QN
vk7PgeWG7G0a8zifaJOggNDGlaQGHo5mk/26t3towWNq8COzQc38e3NR/4ETWNpD
ExiupdmiOH4PI8Qi7fuYzlPVG7xJsHeFTQXKn1KW/VU7pHQn17fad47SwXo9m3Ng
kMEXrr/BZXYbhsw4By70UaZV3hkNYtjsLwoLiYmR/JgquP9fN9+jH9F6HGxuwZkG
AEz3/tDjpG9Xyfbw07YCwwdE9QcYmo6FDT+ReES1nq9HiA5xeojuOs8IwnM2rCrN
1wIDAQAB
-----END PUBLIC KEY-----"""sm_pri_key = 'c124889fb35a23cd3092a62f92ad9f3aafd07876c5bb08bf147ac27b43e15ec7'sm_pub_key = '04aaf5c364472a7b26ab254a834f5b8104ef06387ea7cc9104dd183c6ace0a647a70f19e704721919bcf955a1be8c69c9a9ead286a7d1fdfe067145244c377e1ce'data = "test"print("=========== Sm3WithSm2 ===========")sm_sign = Sm3WithSm2Util.signature(data, sm_pri_key, sm_pub_key)print("Sm3WithSm2 计算后签名:", sm_sign)print("Sm3WithSm2 验签结果:", Sm3WithSm2Util.verify_signature(data, sm_sign, sm_pub_key))print("=========== RsaWithSha256 ===========")rsa_sign = RsaWithSha256Util.signature(data, rsa_pri_key)print("RsaWithSha256 计算后签名:", rsa_sign)print("RsaWithSha256 验签结果:", RsaWithSha256Util.verify_signature(data, rsa_sign, rsa_pub_key))"""
=========== Sm3WithSm2 ===========
Sm3WithSm2 计算后签名: MEUCIHLCP/7f3aAdsxZHH206h65KyTJhm4ceVT1BdTjMEBZwAiEAkzRuMeD1rLQVeC0Tm7MTw/5ssEP9VWxo2dxex3WWjkQ=
Sm3WithSm2 验签结果: True
=========== RsaWithSha256 ===========
RsaWithSha256 计算后签名: FBVEU8nyALWLDKdiJFefcugGrwCcalGoOEDegbZ3N5blLHk5joIUcWHR4giFAYXm3l5wgenRNbToxItBblmGnMVkTSr6um1chGTejKtOu1KZ2koQt4hH5W8+Clc8gniuYfsLZl9W+7idl9oqczXg9vdfUqBOw/Iv1A0uEhpUdGyirf3yc2UduxKouQGGNZbVMTpOjrE4YTXs+Tbz9OIJjv19zQYcVfi1aXX4wiFJbpv/vnUGp7Bvo2FUkvLicf2r1qiPlh0ltX/EfIZmWoNvO6iD/GaQfaA9Z/7VnBhyQxhEeVMi/2KZqoVDDIOM7dIWjmCf1TGy+MDYUxzX+cGRCg==
RsaWithSha256 验签结果: True
"""

python实现RsaWithSHA256签名以及国密Sm3WithSm2签名相关推荐

  1. android 国密签名,关于国密 (sm2,sm3,sm4)在Linux、python、Android、java、ios中的...

    国密即国家密码局认定的国产密码算法.主要有SM1,SM2,SM3,SM4和最新的sm9.在国内环境主要使用的国家密码局认定的算法. SM2算法:SM2椭圆曲线公钥密码算法是我国自主设计的公钥密码算法, ...

  2. 基于mbedTLS算法库实现国密SM2签名和验签算法

    网上有大量的基于OpenSSL实现的国密算法库,比如著名的GmSSL,可以直接拿来用.我自己常用的是mbedTLS的算法库,比较小巧简单,在mbedTLS的大数算法的基础上实现了国密SM2的签名和验签 ...

  3. java 国密p7验签_go/Java 国密sm2签名验签

    近期go项目对接第三方Java服务,第三方要求使用国密sm3/sm2算法进行数据签名验签,特记录go端开发注意事项 1 关于密钥对 密钥生成可以使用openssl库,openssl版本至少是1.1.1 ...

  4. 国密SM2签名之公私钥及证书生成

    一.生成公私钥及证书 1.下载gmssl.jar 2.创建CA密钥 gmssl ecparam -genkey -name sm2p256v1 -out .\ca\CARoot.key 注:若提示 o ...

  5. 使用国密算法签名PDF文件

    技术路线: Java.itextpdf.bouncycastle  加密机直连,实现SM2+SM3 签 PDF,电子签章内容福昕能识别: 具体效果如下:

  6. python商用_python实现sm2和sm4国密(国家商用密码)算法的示例

    GMSSL模块介绍 GmSSL是一个开源的加密包的python实现,支持SM2/SM3/SM4等国密(国家商用密码)算法.项目采用对商业应用友好的类BSD开源许可证,开源且可以用于闭源的商业应用. 安 ...

  7. 国密SM2电子签章JAVA实现

    本文默认所需的国密SM2证书已生成完成.基于BouncyCastle JAR包+itextpdf,利用itext提供的2个签名接口:ExternalDigest 及 ExternalSignature ...

  8. rsa签名算法实现_国密算法在链化未来区块链中的运用

    密码学是区块链的基础,区块链中大量采用了密码学算法,包括对称加密,非对称加密,单向散列算法,数字签名等技术. 为了实现密码学技术的自主可控,中国也定义了自己的国密标准,2020年央行颁布的<金融 ...

  9. fabric 国密改造

    背景 最近应公司项目需求,需要对fabric中的加密相关模块进行改造,主要目的是使fabric底层加密服务支持国密算法sm2.sm3以及sm4等.借这次机会,顺便熟悉一下fabric加密模块的源码实现 ...

最新文章

  1. 【306】通过ArcPy编写ArcToolbox
  2. R可视化包ggplot2设置透明背景实战
  3. 获取android应用签名证书(打包APK用到的那个文件)的SHA1,MD5,SHA256值
  4. T-SQL中的GROUP BY GROUPING SETS
  5. 【Uva11212】 Editing a Book(IDA*)
  6. Android 百度地图Demo
  7. python中range和arange的区别_Python3中range , arange 和linspace 的异同
  8. mysql foundrows 并发_MySQL 中的 FOUND_ROWS() 函数
  9. mysql设置远程登录
  10. paip.图形化编程厉器.net vs2010 工作流WF4 hello word
  11. 端口扫描工具zmap使用笔记
  12. 惠普m1216硒鼓清零步骤_惠普m1136打印机怎么清零
  13. 获得每种调制方式中每个信噪比的准确度
  14. 深度强化学习算法的未来——样本效率研究
  15. 计算机物联网工程专业考研,物联网工程专业考研方向
  16. Java Web-----轮播图的实现
  17. 第三次修正打坐的姿势
  18. C++中rand函数和srand函数
  19. 【Mybatis源码】源码分析
  20. tar.zst 文件格式解压

热门文章

  1. r5 4500u相当于英特尔什么级别 锐龙r54500u相当于i几
  2. PMP考试如何获取PDU
  3. 机器学习160问(建议收藏)
  4. 【Python数据分析之pandas01】两个常用的数据结构
  5. 02335网络操作系统
  6. 错误:Error: Could not open client transport with JDBC Uri: jdbc:hive2://ducking:10000: java.net.Connec
  7. 装水问题,有一侧面看去是半圆的储水装置,该圆的半径为R,要求往水中装入高度为h的水,使水的面积s1与半圆的面积s2的比例为r ,求h (二分法的应用拓展)
  8. 128、易燃气体的概念
  9. 电机控制基础知识储备
  10. AI:华为云HiLens Kit试用测评—全栈全场景的人工智能