后端工具类

@Data
@AllArgsConstructor
static class SM2KeyPair {// 公钥private String publicKey;// 前端公钥private String publicQKey;// 私钥private String privateKey;}// 生成密钥对
public static SM2KeyPair getSm2KeyPair() {SM2 sm2= SmUtil.sm2();// 公钥String publickey=sm2.getPublicKeyBase64();// 前端公钥String publicQkey = HexUtil.encodeHexStr(((BCECPublicKey)sm2.getPublicKey()).getQ().getEncoded(false));// 私钥String privatekey=sm2.getPrivateKeyBase64();return new SM2KeyPair(publickey,publicQkey,privatekey);
}// 公钥加密
public static String encrypt(String data, String publickey) {SM2 sm2=SmUtil.sm2(null,publickey);String encryptStr = sm2.encryptBcd(data, KeyType.PublicKey);return encryptStr;
}// 私钥解密 公钥加密密文
public static String decrypt(String encryptStr, String privatekey){if(!encryptStr.startsWith("04")){encryptStr="04".concat(encryptStr);}SM2 sm2=SmUtil.sm2(privatekey,null);String decryptStr = StrUtil.utf8Str(sm2.decryptFromBcd(encryptStr, KeyType.PrivateKey));return decryptStr;
}// 私钥签名
public static String signByPrivateKey(String data, String privatekey){SM2 sm2= SmUtil.sm2(privatekey,null);String sign = sm2.signHex(HexUtil.encodeHexStr(data));return sign;
}// 公钥验签
public static boolean verifyByPublicKey(String data, String publickey, String signature){SM2 sm2= SmUtil.sm2(null,publickey);boolean verify = sm2.verifyHex(HexUtil.encodeHexStr(data), signature);return verify;
}

生成密钥对:

// 创建私钥、公钥
SM2KeyPair sm2KeyPair = getSm2KeyPair();
// 后端公钥
String publickey = sm2KeyPair.getPublicKey();
// 前端公钥
String publicQkey = sm2KeyPair.getPublicQKey()
// 后端私钥
String privateKey = sm2KeyPair.getPrivateKey();System.out.println("公钥:" + publickey);
System.out.println("私钥:" + privateKey);
System.out.println("------------------");
System.out.println("公钥(前端):" + publicQkey);
公钥:MFkwEwYHKoZIzj0CAQYIKoEcz1UBgi0DQgAEq+OqrQd71xbWD50ks7zfikU7ec64O8fp0d6yuEbadmURoZl4P07I1aEm4bjGvxmP6XP65tqNJWgTDomLhvrpUQ==
私钥:MIGTAgEAMBMGByqGSM49AgEGCCqBHM9VAYItBHkwdwIBAQQgn1ABWedtUoujWXCCwMfKnCXLgj1riMWf/S2SB6xodZKgCgYIKoEcz1UBgi2hRANCAASr46qtB3vXFtYPnSSzvN+KRTt5zrg7x+nR3rK4Rtp2ZRGhmXg/TsjVoSbhuMa/GY/pc/rm2o0laBMOiYuG+ulR
------------------
公钥(前端):04abe3aaad077bd716d60f9d24b3bcdf8a453b79ceb83bc7e9d1deb2b846da766511a199783f4ec8d5a126e1b8c6bf198fe973fae6da8d2568130e898b86fae951

前端使用前端公钥加密

const sm2 = require('sm-crypto').sm2
// 明文
const msgString = '123456abcd你好'
// 公钥(base64)
const publicKey = '04abe3aaad077bd716d60f9d24b3bcdf8a453b79ceb83bc7e9d1deb2b846da766511a199783f4ec8d5a126e1b8c6bf198fe973fae6da8d2568130e898b86fae951'
// 加密
let encryptData = sm2.doEncrypt(msgString, publicKey) // 加密结果
console.log('密文:')
console.log(encryptData)// 密文由后端通过私钥解密
密文:
0ed81be5ba87e0eccdf04ff75e2ce2b75cb9679a237622e2af115311f426437298e39d5a1619429952cc824a4199c50db6b86524a4fbeb224f9be5012ac6c0bc1f6750eb742459b4577ca3a3873463254aea629032d6e7ce4419b981c9fc24eee73ce33fc7ca42064c464fbb399660c1

后端解密

// 后端密钥
String privateKey = "MIGTAgEAMBMGByqGSM49AgEGCCqBHM9VAYItBHkwdwIBAQQgn1ABWedtUoujWXCCwMfKnCXLgj1riMWf/S2SB6xodZKgCgYIKoEcz1UBgi2hRANCAASr46qtB3vXFtYPnSSzvN+KRTt5zrg7x+nR3rK4Rtp2ZRGhmXg/TsjVoSbhuMa/GY/pc/rm2o0laBMOiYuG+ulR";// 密文
String encryptStr = "0e6f7da2aabd4ead9d0aee5e85ba72bdd20f49f28e0f6653674fe235250eec9227c4dec6211289623f77563092fa7c2f36a6fb675eefee7fcb1185cf14c31bb1153875168487f23a400d0e9d25f71d37228cf1c42b76a1a6816771b5169af56c7194fd3c9d3ed7dc5f8bfa063de7b849";// 解密
String decrypt = decrypt(encryptStr, privateKey);
System.out.println(decrypt);
123456abcd你好

使用国密2(SM2)前后端传输加密相关推荐

  1. 前后端传输加密代码-java

    介绍 以下代码均使用RSA加密,适用场景:注册.登录时的密码加密.敏感信息加密等 业务流程: 后端使用RSA算法生成一套密钥 前端使用接口获取后端公钥 后端将公钥传给前端,私钥留在本地服务器 前端使用 ...

  2. 国密算法SM2、SM3的使用

    一.SM2.SM3介绍: 1. SM2是非对称加密算法 它是基于椭圆曲线密码的公钥密码算法标准,其秘钥长度256bit,包含数字签名.密钥交换和公钥加密,用于替换RSA/DH/ECDSA/ECDH等国 ...

  3. 国密算法—SM2介绍及基于BC的实现

    国密算法-SM2介绍及基于BC的实现 文章目录 国密算法-SM2介绍及基于BC的实现 简介 私钥 公钥 数据格式 密钥数据格式 私钥数据格式 公钥数据格式 加密数据格式 签名数据格式 计算过程 生成密 ...

  4. c++国密算法SM2加密解密demo

    c++国密算法SM2加密解密 一.代码 一.代码 封装加密.解密接口: 加密接口: Encrpt_SM2() 解密接口:Decrypt_SM2() 加密解密结果可以和nodejs的模块sm-crypt ...

  5. 国密算法(SM2,SM3,SM4)完善与算法辅助工具开发

    国密算法SM2,SM3和改名发布的SM4的应用好像越来越多了.首先是国密SM2证书的升级,国内CA服务商要完成SM2算法证书支持,之后是国密算法在金融领域进行推广,新近编订的PBOC标准的增强安全部分 ...

  6. 国密算法 SM2 SM3 SM4 及密钥生成

    国密算法 SM2 SM3 SM4 方式一:SM2密钥在线生成 SM2密钥在线生成工具 如果你没线下生成工具,可用下面2种线上生成方式之一: 1. sm2密钥在线生成(const.net.cn) 2.  ...

  7. 国密算法SM2证书制作

    原文链接:http://www.jonllen.com/jonllen/work/162.aspx 国密算法SM2证书制作 分类:工作 大中小 前段时间将系统的RSA算法全部升级为SM2国密算法,密码 ...

  8. 国家医保移动支付国密算法SM2签名验签、SM4加解密DLL

    国家医保移动支付国密算法SM2签名验签.SM4加解密DLL 支持医保移动支付(国家统一版), 已知省份有广西.贵州.安徽.河北.黑龙江.湖南.吉林.江苏.四川.新疆等各地方. DLL,非.net开发, ...

  9. 国密算法 SM2公钥密码 SM3杂凑算法 SM4分组密码 python代码完整实现

    包含SM2公钥密码.SM3杂凑算法和SM4分组密码的国密算法完整工具包完成了.此前分别发布过上述三个算法的代码: SM2:国密算法 SM2 公钥加密 非对称加密 数字签名 密钥协商 python实现完 ...

最新文章

  1. android 获取视频大小,Android 获取视频缩略图(获取视频每帧数据)的优化方案
  2. 非阻塞模式与阻塞模式
  3. 【LDA学习系列】LDA-Python库
  4. 1. Nest Js
  5. python正则表达式中的转义字符_详解python中正则表达式的反斜线的转义功能
  6. Google上面有自己给你标注好的数据集
  7. 主播靠颜值还是???!!!!!
  8. mysql 数据仓库 元数据_数据仓库中的元数据管理
  9. opencv编译找不到nvcuvid.h文件
  10. 番外篇:R or Python,到底学哪个?这篇文章来告诉你......
  11. ODBC数据源无法添加EXCEL驱动,显示存在系统错误代码126:找不到指定模块
  12. java小球落体问题_[Java 编程基本功] (五) 小球落体, 发奖金, 1,2,3,4 可以组成多少个数...
  13. 计算机学院条幅内容,学院迎新活动标语横幅
  14. 分享:从华为转正到离职
  15. 手机通讯录 Python
  16. 某公路边坡支护设计(lunwen+计算书+cad图纸+施工组织设计)
  17. 洛谷P1024 [NOIP2001 提高组] 一元三次方程求解 C++ 思路加代码
  18. 【黑客游戏】学习知识又能玩游戏
  19. 钉钉api接口 Java_服务端对接钉钉三步走
  20. 设计模式系列-调停者模式-Mediator

热门文章

  1. mongodb 限制ip访问
  2. 大宗农产品交易知识图谱推理引擎的构建--需求分析
  3. Jupyter notebook 快捷键
  4. composer proc_open(): fork failed – Cannot allocate memory
  5. 高通平台开发系列讲解(USB篇)linux下U盘识别问题
  6. 华为优招—感受玄学面试
  7. 一节课让你彻底搞懂python里面试最常问问题之一深浅复制
  8. 4 树莓派的分辨率和中文设置
  9. Imagination和完美世界游戏携手推进光线追踪在游戏中的应用
  10. 尚医通 (三十五) --------- 预约下单