root / trunk / web / dojo / dojox / encoding / crypto / RSAKey-ext.js @ 9
History | View | Annotate | Download (2.4 KB)
1 |
/*
|
---|---|
2 |
Copyright (c) 2004-2010, The Dojo Foundation All Rights Reserved.
|
3 |
Available via Academic Free License >= 2.1 OR the modified BSD license.
|
4 |
see: http://dojotoolkit.org/license for details
|
5 |
*/
|
6 |
|
7 |
|
8 |
if(!dojo._hasResource["dojox.encoding.crypto.RSAKey-ext"]){ |
9 |
dojo._hasResource["dojox.encoding.crypto.RSAKey-ext"]=true; |
10 |
dojo.provide("dojox.encoding.crypto.RSAKey-ext");
|
11 |
dojo.experimental("dojox.encoding.crypto.RSAKey-ext");
|
12 |
dojo.require("dojox.encoding.crypto.RSAKey");
|
13 |
dojo.require("dojox.math.BigInteger-ext");
|
14 |
(function(){
|
15 |
var _1=dojox.math.BigInteger;
|
16 |
function _2(d,n){ |
17 |
var b=d.toByteArray();
|
18 |
for(var i=0,_3=b.length;i<_3&&!b[i];++i){ |
19 |
} |
20 |
if(b.length-i!==n-1||b[i]!==2){ |
21 |
return null; |
22 |
} |
23 |
for(++i;b[i];){
|
24 |
if(++i>=_3){
|
25 |
return null; |
26 |
} |
27 |
} |
28 |
var _4=""; |
29 |
while(++i<_3){
|
30 |
_4+=String.fromCharCode(b[i]); |
31 |
} |
32 |
return _4;
|
33 |
}; |
34 |
dojo.extend(dojox.encoding.crypto.RSAKey,{setPrivate:function(N,E,D){ |
35 |
if(N&&E&&N.length&&E.length){
|
36 |
this.n=new _1(N,16); |
37 |
this.e=parseInt(E,16); |
38 |
this.d=new _1(D,16); |
39 |
}else{
|
40 |
throw new Error("Invalid RSA private key"); |
41 |
} |
42 |
},setPrivateEx:function(N,E,D,P,Q,DP,DQ,C){ |
43 |
if(N&&E&&N.length&&E.length){
|
44 |
this.n=new _1(N,16); |
45 |
this.e=parseInt(E,16); |
46 |
this.d=new _1(D,16); |
47 |
this.p=new _1(P,16); |
48 |
this.q=new _1(Q,16); |
49 |
this.dmp1=new _1(DP,16); |
50 |
this.dmq1=new _1(DQ,16); |
51 |
this.coeff=new _1(C,16); |
52 |
}else{
|
53 |
throw new Error("Invalid RSA private key"); |
54 |
} |
55 |
},generate:function(B,E){ |
56 |
var _5=this.rngf(),qs=B>>1; |
57 |
this.e=parseInt(E,16); |
58 |
var ee=new _1(E,16); |
59 |
for(;;){
|
60 |
for(;;){
|
61 |
this.p=new _1(B-qs,1,_5); |
62 |
if(!this.p.subtract(_1.ONE).gcd(ee).compareTo(_1.ONE)&&this.p.isProbablePrime(10)){ |
63 |
break;
|
64 |
} |
65 |
} |
66 |
for(;;){
|
67 |
this.q=new _1(qs,1,_5); |
68 |
if(!this.q.subtract(_1.ONE).gcd(ee).compareTo(_1.ONE)&&this.q.isProbablePrime(10)){ |
69 |
break;
|
70 |
} |
71 |
} |
72 |
if(this.p.compareTo(this.q)<=0){ |
73 |
var t=this.p; |
74 |
this.p=this.q; |
75 |
this.q=t;
|
76 |
} |
77 |
var p1=this.p.subtract(_1.ONE); |
78 |
var q1=this.q.subtract(_1.ONE); |
79 |
var _6=p1.multiply(q1);
|
80 |
if(!_6.gcd(ee).compareTo(_1.ONE)){
|
81 |
this.n=this.p.multiply(this.q); |
82 |
this.d=ee.modInverse(_6);
|
83 |
this.dmp1=this.d.mod(p1); |
84 |
this.dmq1=this.d.mod(q1); |
85 |
this.coeff=this.q.modInverse(this.p); |
86 |
break;
|
87 |
} |
88 |
} |
89 |
_5.destroy(); |
90 |
},decrypt:function(_7){ |
91 |
var c=new _1(_7,16),m; |
92 |
if(!this.p||!this.q){ |
93 |
m=c.modPow(this.d,this.n); |
94 |
}else{
|
95 |
var cp=c.mod(this.p).modPow(this.dmp1,this.p),cq=c.mod(this.q).modPow(this.dmq1,this.q); |
96 |
while(cp.compareTo(cq)<0){ |
97 |
cp=cp.add(this.p);
|
98 |
} |
99 |
m=cp.subtract(cq).multiply(this.coeff).mod(this.p).multiply(this.q).add(cq); |
100 |
} |
101 |
if(!m){
|
102 |
return null; |
103 |
} |
104 |
return _2(m,(this.n.bitLength()+7)>>3); |
105 |
}}); |
106 |
})(); |
107 |
} |