sm2 js java对应版本

SM2是非对称加密算法,网上很难找到正常使用的前后端对应版本,这里为了方便大家不用C币去下载,我这里就直接贴出来需要的代码和工具类了哈

js端

前端的加密会默认把加密内容转base64,所以Java后端解密的时候不转码就会无法还原,sm2Decrypt1()是前端解密的和sm2Encrypt可以配套使用,

function sm2Encrypt(data, publickey, cipherMode) {
    cipherMode = cipherMode == 0 ? cipherMode : 1;
    // msg = SM2.utf8tob64(msg);
    var msgData = CryptoJS.enc.Utf8.parse(data);

    msgData = CryptoJS.enc.Base64.stringify(msgData);
    //在转utf-8
    msgData = CryptoJS.enc.Utf8.parse(msgData);

    var pubkeyHex = publickey;
    if (pubkeyHex.length > 64 * 2) {
        pubkeyHex = pubkeyHex.substr(pubkeyHex.length - 64 * 2);
    }
    var xHex = pubkeyHex.substr(0, 64);
    var yHex = pubkeyHex.substr(64);
    var cipher = new SM2Cipher(cipherMode);
    var userKey = cipher.CreatePoint(xHex, yHex);
    msgData = cipher.GetWords(msgData.toString());
    var encryptData = cipher.Encrypt(userKey, msgData);

    return '04' + encryptData;
}

function sm2Decrypt1(data, privatekey, cipherMode) {
    cipherMode = cipherMode == 0 ? cipherMode : 1;
    // msg = SM2.utf8tob64(msg);
    data = data.substr(2);
    var pk = SM2.tool(privatekey)
    var cipher = new SM2Cipher(cipherMode);
    
    var decryptData = cipher.Decrypt(pk,data);

    decryptData = CryptoJS.enc.Base64.parse(decryptData)
    decryptData = CryptoJS.enc.Utf8.stringify(decryptData);
    return decryptData;
}
function sm2Decrypt(data, privatekey, cipherMode) {
    cipherMode = cipherMode == 0 ? cipherMode : 1;
    // msg = SM2.utf8tob64(msg);
    data = data.substr(2);
    var pk = SM2.tool(privatekey)
    var cipher = new SM2

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值