JS RSA 签名实现

原创 2014年09月03日 13:07:34

折腾了一天半,总算是把JS RSA给弄好了。。。。简单讲下实现。


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

http://kjur.github.io/jsrsasign/  https://github.com/kjur/jsrsasign

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

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

https://github.com/evanvosberg/crypto-js


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


下面讲讲使用。

首先引用想要的库

<script src="http://yui.yahooapis.com/2.9.0/build/yahoo/yahoo-min.js"></script>
    <script src="crypto-js/components/core.js"></script>
    <script src="crypto-js/components/sha1.js"></script>
    <script src="crypto-js/components/md5.js"></script>
    <script src="crypto-js/components/sha256.js"></script>

    <script language="JavaScript" type="text/javascript" src="ext/jsbn.js"></script>
    <script language="JavaScript" type="text/javascript" src="ext/jsbn2.js"></script>
    <script language="JavaScript" type="text/javascript" src="ext/prng4.js"></script>
    <script language="JavaScript" type="text/javascript" src="ext/rng.js"></script>
    <script language="JavaScript" type="text/javascript" src="ext/rsa.js"></script>
    <script language="JavaScript" type="text/javascript" src="ext/rsa2.js"></script>
    <script language="JavaScript" type="text/javascript" src="ext/base64.js"></script>


    <script language="JavaScript" type="text/javascript" src="jsrsasign/rsapem-1.1.js"></script>
    <script language="JavaScript" type="text/javascript" src="jsrsasign/rsasign-1.2.js"></script>
    <script language="JavaScript" type="text/javascript" src="jsrsasign/asn1hex-1.1.js"></script>
    <script language="JavaScript" type="text/javascript" src="jsrsasign/crypto-1.1.js"></script>
    <script language="JavaScript" type="text/javascript" src="jsrsasign/pkcs5pkey-1.0.js"></script>
    <script language="JavaScript" type="text/javascript" src="jsrsasign/base64x-1.1.js"></script>
    <script language="JavaScript" type="text/javascript" src="jsrsasign/keyutil-1.0.js"></script>


这是我一次性引入的,主要是参考了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的资料真的好少,希望给后来者一点参考。

AES+RSA加密解密(js和java互通)

客户端和服务端数据加解密流程图 案例 1、客户端生成aes秘钥 js function getAesKey(len) {   len = len || 32;   ...
  • qq_18837459
  • qq_18837459
  • 2017-07-13 18:00:42
  • 549

加/解密系列(三)-前端加密JS库--CryptoJS

效果如图(一个采用Crypto-JS实现的工具展示): CryptoJS (crypto.js) 为 JavaScript 提供了各种各样的加密算法。目前已支持的算法包括: MD5 SHA-...
  • linfanhehe
  • linfanhehe
  • 2017-07-21 17:08:24
  • 970

前端ajax请求添加rsa签名,nodejs请求添加签名,nodejs api添加验签

前端ajax请求添加rsa签名 如何使用openssl生成私钥 公钥 http://blog.csdn.net/scape1989/article/details/18959657教程 :https...
  • sinat_29843547
  • sinat_29843547
  • 2017-05-26 11:55:19
  • 1407

RSA算法 JS加密 JAVA解密

有这样一个需求,前端登录的用户名密码,密码必需加密,但不可使用MD5,因为后台要检测密码的复杂度,那么在保证安全的前提下将密码传到后台呢,答案就是使用RSA非对称加密算法解决 。java代码需要依赖 ...
  • dounine
  • dounine
  • 2017-04-13 17:47:20
  • 18452

Node-RSA 验证签名

/** * Created by Bluesky on 2015/9/8. */ var crypto = require('crypto'); /** * 验证签名 * @param src...
  • QingKong999
  • QingKong999
  • 2015-09-09 12:10:11
  • 3938

Nodejs做RSA验证实例与豌豆荚RSA验证的实现,支付宝的RSA也一样可以使用,0.0

首先这里告诉大家一些简单的nodejs对RS
  • macjeson
  • macjeson
  • 2014-07-29 10:55:08
  • 2177

JavaScript RSA加密库Cryptico.js

转自:http://www.open-open.com/news/view/27cfef Cryptico.js 是一个易于使用的JavaScript工具包用于在客户端对文本进行加密。 ...
  • gf771115
  • gf771115
  • 2015-02-04 13:43:20
  • 20802

rsa的js加密库

  • 2015年10月31日 20:03
  • 9KB
  • 下载

关于使用JS前台加密、JAVA后台解密的RSA实现,RSA加密和签名

需求环境: 西安项目中,客户要求保护用户的密码信息,不允许在http中传递明文的密码信息。   实现: 用RSA非对称加密方式实现。后台生成rsa密钥对,然后在登陆页面设置rs...
  • zengdejie123
  • zengdejie123
  • 2017-04-07 16:39:01
  • 8184
收藏助手
不良信息举报
您举报文章:JS RSA 签名实现
举报原因:
原因补充:

(最多只允许输入30个字)