客户端使用公钥进行加密,服务端使用密钥进行解密
来源:互联网 发布:欧洲知乎 编辑:程序博客网 时间:2024/06/03 15:21
使用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<b.length;n++){
stmp=(java.lang.Integer.toHexString(b[n]&
0XFF
));
if
(stmp.length()==
1
)hs=hs+
"0"
+stmp;
else
hs=hs+stmp;
if
(n<b.length-
1
) hs=hs+
":"
;
}
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);
}
}
0 0
- 客户端使用公钥进行加密,服务端使用密钥进行解密
- 使用openssl进行加密解密
- 使用DES进行加密解密
- 使用md5进行加密解密
- C#使用RSA进行私钥加密公钥解密
- C#使用RSA进行私钥加密公钥解密
- 使用Botan进行RSA公有密钥加密
- 服务端使用3DES解密,客户端使用3DES加密
- iOS 客户端进行 RSA 加密并在 PHP 服务端进行解密
- 使用密钥加密、解密实例
- 如何使用Base64进行加密和解密
- 使用DPAPI进行数据加密解密
- 使用openssl api进行加密解密
- 如何使用Base64进行加密和解密
- 如何使用Base64进行加密和解密
- 使用C# Base64进行加密和解密
- Java中使用DES进行加密解密
- 使用CryptoAPI对文件进行加密解密
- JVM系列一:JVM内存组成及分配
- MQTT协议之Mosquitto安装和使用
- 关于论坛数据库的设计(分表分库等-转)
- POJ-1411 & HDOJ-1239 Calling Extraterrestrial Intelligence Again 解题报告
- JVM系列二:GC策略&内存申请、对象衰老
- 客户端使用公钥进行加密,服务端使用密钥进行解密
- Android字符串资源及其格式化
- centOs5.10 下安装svn服务器
- eclipse提示No grammar constraints (DTD or XML schema).....两种解决方法
- KVC 与 KVO
- lua 基础语法
- CMD常用命令
- MySQL · 捉虫动态· InnoDB自增列重复值问题
- C语言中volatile关键字的作用