js rsa验签_JS RSA 签名实现

本文介绍如何使用JSRSASign库进行签名操作,包括下载必要的库文件、配置密钥及签名方式等步骤。重点讲解了在浏览器环境下如何实现RSA签名。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先去下载jsrsasign的库,这个库是纯js的,不依赖于openssl,所以可以在浏览器直接使用,当然后端的nodejs也是可以用的。比较通用。

这个库依赖一个crypto-js库,他的例子里面很多是从googlecode里面直接使用,不过,由于我们都知道的原因,这个是无法访问的。

幸好有人把它从googlecode移动了一份到github

都下载以后,把库放到站点的目录上。

下面讲讲使用。

首先引用想要的库

这是我一次性引入的,主要是参考了jsrsasign里面的test页面,估计有点多。。。。

我本来想使用requirejs的,不过,不大会用。。。

然后要根据配置读取key,配置sign方式。

var prvKey = KEYUTIL.getRSAKeyFromPlainPKCS8PEM(pem); // KEYUTIL提供了PKCS#8的pem读取,这是一般用openssl生成的默认。而jsrsasign的默认是PKCS#1 所以需要用keyutil

var sig = new KJUR.crypto.Signature({"alg": "MD5withRSA", "prov": "cryptojs/jsrsa"}); // alg为MD5WithRSA,这个还有个常见的是SHA1WithRSA,不过貌似支付宝是用的MD5,所以我们公司用的也是MD5,也许java默认的就是这个格式。

sig.initSign(prvKey);  // 设置key

sig.signString(signString);  // 签名

var sign = hex2b64(s4.hSign);  // 得到签名Hex,并转成base64string

对了,还需要注意的是,pem的头,不是

BEGIN RSA PRIVATE KEY

而是

BEGIN PRIVATE KEY

其实后者是我用openssl里面生成就是这样的,我不知道为啥会是上面的那种头,没仔细研究。

大功告成。

哦了,简明攻略在此。jsrsa的资料真的好少,希望给后来者一点参考。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值