首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

小程序安全键盘&SM2解密方式

小程序安全键盘&SM2解密方式 转载请著名出处:https://www.cnblogs.com/funnyzpc/p/17572445.html SM2基本信息 私钥(primary key) 6082011f17b21dab7da93f2dc1a739b530b969171c7116bebb0535a953e20bae...基本信息 先看看 SM2 Encrypt/Decrypt 格式选择里面有四种模式,其中C1C3C2是SM2的其中一种模式 ASN1是SM2的文本编码方式,事实上这些也是微信键盘所使用的编码加密方式...这个东东可能是是在SM2加密前也可能是加密后做的编码行为 3.基于[2]知道开发需要一套能实现SM2以及ASN1编码的功能的库 首先准备一个实现库,这里我用的是gmhelper(感谢 Lijun Liao...decrypt result: " + dec_str); } 对于以上实现需要注意的是: 1.解密前必须要削掉A02_开头字符 2.解密后的明文中会有\0分割各个block,需要自行split...3.明文在解密前以及解密后都是HEX(16进制) 4.在开发前建议使用工具(Windows_SMCryptoTools/Mac_SMCryptoTools)先行测试,过不了工具这关联调肯定也是不行的!

47241

详解国密SM2的加密和解密

在上一篇文章《解读国密非对称加密算法SM2》介绍了国密非对称算法SM2,在文章中说到,如果现有的网络库中已经实现ECC算法,只需加入SM2命名曲线的参数即可。...但在实现ECC_SM4_SM3这个密码套件中,在密钥交换过程中,存在客户端将Pre-Master Secret使用 SM2 公钥加密后传给服务器端的步骤。所以我们需要实现 SM2 的加密和解密。...如何使用 SM2 算法进行加密和解密,可以参考的资料是《GMT 0003.4-2012 SM2椭圆曲线公钥密码算法第4部分:公钥加密算法》。...我在本地实现了SM2的加密和解密,使用 《GMT 0003.4-2012》文档附录中的数据进行测试,也都通过,但在与第三方服务器端对接时,总是解密失败,后来才发现是因为这个原因。...国密文档中关于解密流程的描述: ? 实现了加密流程后,解密流程的实现就简单了,这里不再过多描述。

5.5K40
您找到你想要的搜索结果了吗?
是的
没有找到

从零玩转前后端加解密SM2

前言SM2是国家密码管理局于2010年12月17日发布的椭圆曲线公钥密码算法。SM2算法和RSA算法都是公钥密码算法,SM2算法是一种更先进安全的算法,在我们国家商用密码体系中被用来替换RSA算法。...随着密码技术和计算机技术的发展,目前常用的1024位RSA算法面临严重的安全威胁,我们国家密码管理部门经过研究,决定采用SM2椭圆曲线算法替换RSA算法。...SM2算法和RSA算法比较SM2性能更优更安全:密码复杂度高、处理速度快、机器性能消耗更小详细参考: https://www.ecaa.org.cn/667.htmlSM2...dependency>获取密钥对 @org.junit.Test public void generateKeyPairHex (){ // 生成出来的密钥可无缝衔接 前端 js 加解密...final String s = Sm2.doDecrypt(doEncrypt, privateKey); System.out.println("解密:\n" + s)

79840

SM 国密算法踩坑指南

公钥可以用于加密,私钥可以用于解密 同样 SM2 算法也有一对公私钥,它们的长度远远小于 RSA 公私钥。...SM2 公钥加密算法 SM2 加密算法也是比较复杂,这里只截取加密、解密原理 详细文档可以搜索:『GB/T 32918.4—2016 信息安全技术 SM2椭圆曲线公钥 密码算法 第4部分:公钥加密算法』...sm2 加密算法 SM2解密算法 SM2 加密数据 SM2 加密数据将会产生三个值: C1 为随机产生的公钥 C2 为密文,与明文长度等长 C3 为 SM3 算法对明文数计算得到消息摘要...这里需要注意一点,有些加密数据格式也会使用 C1|C2|C3,加解密之间需要注意格式。...如果直接拿硬件加密方案生成加密结果,然后直接使用软件加密方案去解密,就会导致解密失败。 SM2 算法联调测试的时候,这一点比较头疼,下面讲下这次国密改造中碰到一些问题。

6.5K21

关于SM2算法工具的一点儿说明

而要看能否解密出来。若果还有其他疑问,欢迎留言或者加我QQ联系。...推荐几个网上测试sm2的网站: SM2解密 SM2 在线加密工具 可以这样测试下: 用我的工具加密,使用同样的密钥,用网上的工具解密,看解密出来的明文是否正确。...以下是我的验证: 图片 网上工具算的如下,使用相同的秘钥,把工具生成的密文在网站上输入进去解密以下。解密结果如图所示: 再来测下验签: 用工具生成的签名,填入网站里去验签,看能否通过。...图片  需要注意的是,如果使用网站上生成的签名,拿这个工具验签的话,需要在xB(公钥x的位置)最前面补上个02或03.否则会收到提示: ====sm2签名验证==== tips:目前仅支持压缩公钥,...SM2一般用到的或者第三方提供的公钥都是压缩过的,长度为66个长度,既33字节。其实yB不需要输入,有了xB的压缩公钥,yB工具自己就算出来了。

39010

SM2? SM3? SM4?

SM2 和国际上通过的RSA一样,是一种非对称加密算法,使用公钥加密,私钥解密,在安全性和运算速度方面要优于RSA算法。 SM3 可以用来生成信息摘要,如MD5,生成的信息摘要长度为256位。...了解了SM2, SM3, SM4这些算法之后,在我们的系统中就可以应用这些算法来对传输的报文进行加解密;一个简单的流程图如下所示: ?...第三步,通过 ECC 密钥对获取SM2公钥和私钥,代码如下: ? 第四步,获取到公钥之后,就可以使用公钥对报文进行加密了,代码如下: ? 第五步,加密之后,需要使用私钥来进行解密,代码如下: ?...到这里使用Java来实现SM2解密算法已经结束了,是不是很简单,你学废了吗?...: /** * SM2 私钥解密 * * @param sm2PrivateKey SM2 私钥 * @param pack 解密报文 * @throws Exception

2.2K31

PKI - 一文读懂SM1、SM2、SM3、SM4等国密算法

Pre Java - 深入理解加密解密和签名算法 概述 国密即国家密码局认定的国产密码算法。主要有SM1,SM2,SM3,SM4。密钥长度和分组长度均为128位。...另外SM4在加密解密需要相同的密钥,这个我们可以通过编写密钥交换模块实现生成相同的密钥。用于SM4对称加密。...关于非对称还要注意几点: (1)公钥是通过私钥产生的; (2)公钥加密,私钥解密是加密的过程 (3)私钥加密,公钥解密是签名的过程; 由于SM1、SM4加解密的分组大小为128bit,故对消息进行加解密时...分组长度:SM4算法的分组长度也为128比特,这意味着每次加密或解密的数据块大小为128比特。这一分组长度可以确保数据的机密性和完整性。...非对称加密SM2 使用随机生成的密钥对加密或解密 String text = "我是一段测试aaaa"; SM2 sm2 = SmUtil.sm2(); // 公钥加密,私钥解密 String encryptStr

3K00

记一次国密落地的经历

优点:保密性好,完整的加解密方案(包括证书、信任链等待)缺点:需要在业务侧缓存大量SM4密钥,对性能有影响XXX网关团队数据加密方案:一次链接一个SM4密钥,发送SM4加密的数据同时发送SM2公钥加密后的...优点:过程简单缺点:服务端每次数据处理都需要双解密解密密钥后解密数据),对性能有影响无侵入数据加密方案:使用双SSL证书(RSA/SM2)的HTTPS前置机作为网络入口,完全无侵入性地替换。...SM2公钥支持上报失败后数据加密落地重传可以接受的缺点:对业务侵入于是在制定方案时我们充分考量了HTTPS加解密方式,设计了类似的加密上报方式基于对称密钥加密公钥的非对称加密方案,时序图如下: sequenceDiagram...钥匙对值得注意的是:为了确保解密后数据无误,同时上报原始数据MD5用以比对为了确保服务器更新SM2公钥后上报仍然可以进行,我们设计了主从密钥方式,被换下的密钥并不删除,而是作为从钥继续用以解密,并且通知终端更新公钥为了确保上报失败后可以重试.../** * @brief 使用SM2获取公私钥或加解密之前,必须调用SM2InitCtx或者SM2InitCtxWithPubKey函数.如果使用固定公钥加密,可调用SM2InitCtxWithPubKey

1.2K22

KonaJDK 8 新版本更新,国密算法轻松用

),或者秘钥(SM4), 获取 Consumer 提供的加密数据之后进行解密。...Provider 接收后会将数据解密并返回给 Consumer, 这里就是存储在 result 中。...,包含公钥与私钥,并返回公钥给 Consumer ; 针对 SM4 生成秘钥并返回给 Consumer : 获取SM2/SM4加密的密文并解密 使用 SM3 计算 hash digest 注意上图的代码中已经包含了使用...例如: (1)SM2 数据加密与解密 ~$ curl http://localhost:18083/echo-rest/getkeysm2            --(获取 SM2 公钥) MDQyMWJkNGY0ZDU0Y2U5MGIyMTY5NWVhNmRkNDRjN2M3NWY5MzE5OTc4OGQwOGZiNzA4NjJlNjE4NjYzYjJkMGQ0ZWFiODY3MzNiMDFlNTczN2E3MjkxNTE5NjgzODYxM2NlMjQyMTZkYjExNjE2NmFiYTVmYTFjNDZhM2RiYzcwNw...”) provider get secret: IamSecretData --( Provider 解密后的数据打印) (2)SM4 数据加密与解密 ~$ curl http://localhost:

1.4K60

漏洞分析 | OpenSSL国密爆出8.1分高危漏洞CVE-2021-3711

漏洞分析 根据官网披露的信息细节https://www.openssl.org/news/secadv/20210824.txt 得出如下分析: 漏洞原因:SM2解密时分配了一块内存,解密后的结果可能大于该分配内存的容量...1、OpenSSL EVP解密操作 OpenSSL EVP将常用的密码算法进行了封装,提供统一的密码学各种函数。 看示例图找规律,OpenSSL对密文的解密是什么样的操作?...0 : *outlen), in, inlen); return ret; legacy: ... } 3、pkey_sm2_decrypt实现 对于SM2解密,EVP_PKEY_decrypt...第二次调用pkey_sm2_decrypt,由于密文有11字节,因此解密结果也是11字节。 out指向的内存是10字节,而解密结果是11字节,导致越界写1字节。...TencentSM符合国密SM2、SM3以及SM4算法标准,已在腾讯多个业务中平稳运行。 TencentSM自研了SM2解密实现,未使用和参考OpenSSL该部分所对应的代码,不受该漏洞影响。

1.8K40

KonaJDK 助力微服务国密算法使用特性一览

),或者秘钥(SM4), 获取 Consumer 提供的加密数据之后进行解密。...Provider 接收后会将数据解密并返回给 Consumer, 这里就是存储在 result 中。...,包含公钥与私钥,并返回公钥给 Consumer ; 针对 SM4 生成秘钥并返回给 Consumer : 获取SM2/SM4加密的密文并解密 使用 SM3 计算 hash digest 注意上图的代码中已经包含了使用...例如: SM2 数据加密与解密 ~$ curl http://localhost:18083/echo-rest/getkeysm2            --(获取 SM2 公钥) MDQyMWJkNGY0ZDU0Y2U5MGIyMTY5NWVhNmRkNDRjN2M3NWY5MzE5OTc4OGQwOGZiNzA4NjJlNjE4NjYzYjJkMGQ0ZWFiODY3MzNiMDFlNTczN2E3MjkxNTE5NjgzODYxM2NlMjQyMTZkYjExNjE2NmFiYTVmYTFjNDZhM2RiYzcwNw...”) provider get secret: IamSecretData --( Provider 解密后的数据打印) SM4 数据加密与解密 ~$ curl http://localhost:18083

71330

国密算法「建议收藏」

SM2算法 SM2算法:SM2椭圆曲线公钥密码算法是我国自主设计的公钥密码算法,包括SM2-1椭圆曲线数字签名算法,SM2-2椭圆曲线密钥交换协议,SM2-3椭圆曲线公钥加密算法,分别用于实现数字签名密钥协商和数据加密等功能...SM2算法与RSA算法不同的是,SM2算法是基于椭圆曲线上点群离散对数难题,相对于RSA算法,256位的SM2密码强度已经比2048位的RSA密码强度要高 学习sm2算法,首先学习ECC算法 ECC...在总则的基础上给出了数字签名算法(包括数字签名生成算法和验证算法),密钥交换协议以及公钥加密算法(包括加密算法和解密算法),并在每个部分给出了算法描述,算法流程和相关示例。...解密算法与加密算法的结构相同,只是轮密钥的使用顺序相反,解密轮密钥是加密轮密钥的逆序。...解密算法:SM4密码算法是对合运算,因此解密算法与加密算法的结构相同,只是轮密铝的使用顺序相反,解密轮密钥是加密轮密钥的逆序。

1.8K20

KonaJDK 助力微服务国密算法使用特性一览

),或者秘钥(SM4), 获取 Consumer 提供的加密数据之后进行解密。...Provider 接收后会将数据解密并返回给 Consumer, 这里就是存储在 result 中。...,包含公钥与私钥,并返回公钥给 Consumer ; 针对 SM4 生成秘钥并返回给 Consumer : 获取SM2/SM4加密的密文并解密 使用 SM3 计算 hash digest 注意上图的代码中已经包含了使用...例如: SM2 数据加密与解密 ~$ curl http://localhost:18083/echo-rest/getkeysm2            --(获取 SM2 公钥) MDQyMWJkNGY0ZDU0Y2U5MGIyMTY5NWVhNmRkNDRjN2M3NWY5MzE5OTc4OGQwOGZiNzA4NjJlNjE4NjYzYjJkMGQ0ZWFiODY3MzNiMDFlNTczN2E3MjkxNTE5NjgzODYxM2NlMjQyMTZkYjExNjE2NmFiYTVmYTFjNDZhM2RiYzcwNw...”) provider get secret: IamSecretData --( Provider 解密后的数据打印) SM4 数据加密与解密 ~$ curl http://localhost:18083

78240

爬虫逆向基础,认识 SM1-SM9、ZUC 国密算法

国密即国家密码局认定的国产加密算法,爬虫工程师在做 JS 逆向的时候,会遇到各种各样的加密算法,其中 RSA、AES、SHA 等算法是最常见的,这些算法都是国外的,在 K 哥以前的文章里也有介绍:《【爬虫知识】爬虫常见加密解密算法...【03x02】SM2 椭圆曲线公钥加密算法 SM2 为椭圆曲线(ECC)公钥加密算法,非对称加密,SM2 算法和 RSA 算法都是公钥加密算法,SM2 算法是一种更先进安全的算法,在我们国家商用密码体系中被用来替换...加密算法与密钥扩展算法都采用 32 轮非线性迭代结构,解密算法与加密算法的结构相同,只是轮密钥的使用顺序相反,解密轮密钥是加密轮密钥的逆序。...以 gmssl 的 SM2 算法为例,实现如下(其他算法和详细用法可参考其官方文档): SM2 加密(encrypt)和解密(decrypt): from gmssl import sm2 # 16...和解密(decrypt): const sm2 = require('sm-crypto').sm2 // 1 - C1C3C2,0 - C1C2C3,默认为1 const cipherMode =

2K20

即时通讯安全篇(十三):信创必学,一文读懂什么是国密算法

利用SM2非对称加密算法加解密数据的过程:6.3密钥协商由于椭圆曲线的计算复杂性高,破解难度大,因此SM2算法在密钥协商技术领域也起着关键作用。...3) 用户A的明文数据和数字签名经加密算法(SM1/SM2/SM4)加密成密文后发送给用户B。加密算法以非对称加密算法SM2为例,即加解密使用不同密钥。...4)密文到达用户B处,经加密算法(SM1/SM2/SM4)解密后,还原成明文数据和数字签名。...2)在身份认证阶段,本端使用SM2和SM3算法生成身份信息的数字签名,并使用SM1或SM4算法和会话密钥对身份信息和数字签名进行加密;对端收到加密的身份信息后,使用相同的会话密钥解密,然后通过SM2和SM3...3)在数据传输阶段,本端使用SM2和SM3算法生成用户数据的数字签名,并使用SM1或SM4算法以及会话密钥对用户数据和数字签名进行加密;对端收到加密的用户数据后,使用相同的会话密钥解密,然后通过SM2

1.5K10
领券