使用rsa非对称加密吧,客户端使用公钥进行加密,服务端使用密钥进行解密。
我觉得你最好使用JAVA 进行DES加密和解密
(JAVA 的核心API中已经实现过DES加密,JAVASCRIPT实现DES加密我没做过)
下面是JAVA版的DES加密 希望对你有帮助:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
|
import
java.security.Key;
import
java.security.SecureRandom;
import
javax.crypto.Cipher;
import
javax.crypto.KeyGenerator;
import
sun.misc.BASE64Decoder;
import
sun.misc.BASE64Encoder;
public
class
Des {
Key key;
/**
* 根据参数生成KEY
* @param strKey
*/
public
void
getKey(String strKey) {
try
{
KeyGenerator _generator = KeyGenerator.getInstance(
"DES"
);
_generator.init(
new
SecureRandom(strKey.getBytes()));
this
.key = _generator.generateKey();
_generator =
null
;
}
catch
(Exception e) {
e.printStackTrace();
}
}
/**
* 加密String明文输入,String密文输出
* @param strMing String明文
* @return String密文
*/
public
String getEncString(String strMing) {
byte
[] byteMi =
null
;
byte
[] byteMing =
null
;
String strMi =
""
;
BASE64Encoder base64en =
new
BASE64Encoder();
try
{
byteMing = strMing.getBytes(
"UTF8"
);
byteMi =
this
.getEncCode(byteMing);
strMi = base64en.encode(byteMi);
}
catch
(Exception e) {
e.printStackTrace();
}
finally
{
base64en =
null
;
byteMing =
null
;
byteMi =
null
;
}
return
strMi;
}
/**
* 解密 以String密文输入,String明文输出
* @param strMi String密文
* @return String明文
*/
public
String getDesString(String strMi) {
BASE64Decoder base64De =
new
BASE64Decoder();
byte
[] byteMing =
null
;
byte
[] byteMi =
null
;
String strMing =
""
;
try
{
byteMi = base64De.decodeBuffer(strMi);
byteMing =
this
.getDesCode(byteMi);
strMing =
new
String(byteMing,
"UTF8"
);
}
catch
(Exception e) {
e.printStackTrace();
}
finally
{
base64De =
null
;
byteMing =
null
;
byteMi =
null
;
}
return
strMing;
}
/**
* 加密以byte[]明文输入,byte[]密文输出
* @param byteS
* @return
*/
private
byte
[] getEncCode(
byte
[] byteS) {
byte
[] byteFina =
null
;
Cipher cipher;
try
{
cipher = Cipher.getInstance(
"DES"
);
cipher.init(Cipher.ENCRYPT_MODE, key);
byteFina = cipher.doFinal(byteS);
}
catch
(Exception e) {
e.printStackTrace();
}
finally
{
cipher =
null
;
}
return
byteFina;
}
/**
* 解密以byte[]密文输入,以byte[]明文输出
* @param byteD
* @return
*/
private
byte
[] getDesCode(
byte
[] byteD) {
Cipher cipher;
byte
[] byteFina =
null
;
try
{
cipher = Cipher.getInstance(
"DES"
);
cipher.init(Cipher.DECRYPT_MODE, key);
byteFina = cipher.doFinal(byteD);
}
catch
(Exception e) {
e.printStackTrace();
}
finally
{
cipher =
null
;
}
return
byteFina;
}
//转化为16进制字符串
public
static
String byte2hex(
byte
[] b){
String hs=
""
;
String stmp=
""
;
for
(
int
n=
0
;n
stmp=(java.lang.Integer.toHexString(b[n]&
0XFF
));
if
(stmp.length()==
1
)hs=hs+
"0"
+stmp;
else
hs=hs+stmp;
if
(n
}
return
hs.toUpperCase();
}
public
static
void
main(String args[]) {
Des des=
new
Des();
//实例化一个对像
des.getKey(
"aadd"
);
//生成密匙
String strEnc = des.getEncString(
"明文"
);
//加密字符串,返回String的密文
System.out.println(
"加密文:"
+strEnc);
String strDes = des.getDesString(strEnc);
//把String 类型的密文解密
System.out.println(
"解密文:"
+strDes);
}
}
|