安装依赖
npm install --save sm-crypto
使用方法
需要向后端要去公钥
const sm2 = require('sm-crypto').sm2
const cipherMode = 1 // 1 - C1C3C2,0 - C1C2C3,默认为1
let pwd= sm2.doEncrypt(this.password, "公钥", cipherMode) // sm2加密
可能出现的问题
- 加密后传给后端的解密不出来,需要在加密后的密文前面加上04
- 加密后传给后端的是乱码,那就需要使用base64进行编码,再用SM2加密,如果还不行就在加上04吧
拓展介绍
- sm-crypto是国密算法sm2、sm3和sm4的js版
- 什么是国密?国密算法是国家密码管理局制定的自主可控的国产算法,包括SM1、SM2、SM3 、SM4、SM7、SM9、祖冲之密码算法(ZUC)等。在金融领域目前主要使用公开的SM2、SM3、SM4三种商用密码算法,分别为非对称加密算法、哈希算法和对称加密算法。
- sm-crypto也可以生成签名等等,可以冲链接跳转了解