一、DES加密和解密
一、DES加密和解密
原文:http://www.jb51.net/article/51879.htm 还有其他文章
|
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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
|
package com.itjh.javaUtil;import java.io.UnsupportedEncodingException;import java.security.InvalidKeyException;import java.security.NoSuchAlgorithmException;import java.security.SecureRandom;import java.security.spec.InvalidKeySpecException;import javax.crypto.BadPaddingException;import javax.crypto.Cipher;import javax.crypto.IllegalBlockSizeException;import javax.crypto.KeyGenerator;import javax.crypto.NoSuchPaddingException;import javax.crypto.SecretKey;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.DESKeySpec;/** * DES加密和解密。 * * @author 宋立君 * @date 2014年07月03日 */public class DESUtil { /** 安全密钥 */ private String keyData = "ABCDEFGHIJKLMNOPQRSTWXYZabcdefghijklmnopqrstwxyz0123456789-_."; /** * 功能:构造 * * @author 宋立君 * @date 2014年07月03日 */ public DESUtil() { } /** * 功能:构造 * * @author 宋立君 * @date 2014年07月03日 * @param keyData * key */ public DESUtil(String key) { this.keyData = key; } /** * 功能:加密 (UTF-8) * * @author 宋立君 * @date 2014年07月03日 * @param source * 源字符串 * @param charSet * 编码 * @return String * @throws UnsupportedEncodingException * 编码异常 */ public String encrypt(String source) throws UnsupportedEncodingException { return encrypt(source, "UTF-8"); } /** * * 功能:解密 (UTF-8) * * @author 宋立君 * @date 2014年07月03日 * @param encryptedData * 被加密后的字符串 * @return String * @throws UnsupportedEncodingException * 编码异常 */ public String decrypt(String encryptedData) throws UnsupportedEncodingException { return decrypt(encryptedData, "UTF-8"); } /** * 功能:加密 * * @author 宋立君 * @date 2014年07月03日 * @param source * 源字符串 * @param charSet * 编码 * @return String * @throws UnsupportedEncodingException * 编码异常 */ public String encrypt(String source, String charSet) throws UnsupportedEncodingException { String encrypt = null; byte[] ret = encrypt(source.getBytes(charSet)); encrypt = new String(Base64.encode(ret)); return encrypt; } /** * * 功能:解密 * * @author 宋立君 * @date 2014年07月03日 * @param encryptedData * 被加密后的字符串 * @param charSet * 编码 * @return String * @throws UnsupportedEncodingException * 编码异常 */ public String decrypt(String encryptedData, String charSet) throws UnsupportedEncodingException { String descryptedData = null; byte[] ret = descrypt(Base64.decode(encryptedData.toCharArray())); descryptedData = new String(ret, charSet); return descryptedData; } /** * 加密数据 用生成的密钥加密原始数据 * * @param primaryData * 原始数据 * @return byte[] * @author 宋立君 * @date 2014年07月03日 */ private byte[] encrypt(byte[] primaryData) { /** 取得安全密钥 */ byte rawKeyData[] = getKey(); /** DES算法要求有一个可信任的随机数源 */ SecureRandom sr = new SecureRandom(); /** 使用原始密钥数据创建DESKeySpec对象 */ DESKeySpec dks = null; try { dks = new DESKeySpec(keyData.getBytes()); } catch (InvalidKeyException e) { e.printStackTrace(); } /** 创建一个密钥工厂 */ SecretKeyFactory keyFactory = null; try { keyFactory = SecretKeyFactory.getInstance("DES"); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } /** 用密钥工厂把DESKeySpec转换成一个SecretKey对象 */ SecretKey key = null; try { key = keyFactory.generateSecret(dks); } catch (InvalidKeySpecException e) { e.printStackTrace(); } /** Cipher对象实际完成加密操作 */ Cipher cipher = null; try { cipher = Cipher.getInstance("DES"); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (NoSuchPaddingException e) { e.printStackTrace(); } /** 用密钥初始化Cipher对象 */ try { cipher.init(Cipher.ENCRYPT_MODE, key, sr); } catch (InvalidKeyException e) { e.printStackTrace(); } /** 正式执行加密操作 */ byte encryptedData[] = null; try { encryptedData = cipher.doFinal(primaryData); } catch (IllegalStateException e) { e.printStackTrace(); } catch (IllegalBlockSizeException e) { e.printStackTrace(); } catch (BadPaddingException e) { e.printStackTrace(); } /** 返回加密数据 */ return encryptedData; } /** * 用密钥解密数据 * * @param encryptedData * 加密后的数据 * @return byte[] * @author 宋立君 * @date 2014年07月03日 */ private byte[] descrypt(byte[] encryptedData) { /** DES算法要求有一个可信任的随机数源 */ SecureRandom sr = new SecureRandom(); /** 取得安全密钥 */ byte rawKeyData[] = getKey(); /** 使用原始密钥数据创建DESKeySpec对象 */ DESKeySpec dks = null; try { dks = new DESKeySpec(keyData.getBytes()); } catch (InvalidKeyException e) { e.printStackTrace(); } /** 创建一个密钥工厂 */ SecretKeyFactory keyFactory = null; try { keyFactory = SecretKeyFactory.getInstance("DES"); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } /** 用密钥工厂把DESKeySpec转换成一个SecretKey对象 */ SecretKey key = null; try { key = keyFactory.generateSecret(dks); } catch (InvalidKeySpecException e) { e.printStackTrace(); } /** Cipher对象实际完成加密操作 */ Cipher cipher = null; try { cipher = Cipher.getInstance("DES"); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (NoSuchPaddingException e) { e.printStackTrace(); } /** 用密钥初始化Cipher对象 */ try { cipher.init(Cipher.DECRYPT_MODE, key, sr); } catch (InvalidKeyException e) { e.printStackTrace(); } /** 正式执行解密操作 */ byte decryptedData[] = null; try { decryptedData = cipher.doFinal(encryptedData); } catch (IllegalStateException e) { e.printStackTrace(); } catch (IllegalBlockSizeException e) { e.printStackTrace(); } catch (BadPaddingException e) { e.printStackTrace(); } return decryptedData; } /** * 取得安全密钥 此方法作废,因为每次key生成都不一样导致解密加密用的密钥都不一样, 从而导致Given final block not * properly padded错误. * * @return byte数组 * @author 宋立君 * @date 2014年07月03日 */ private byte[] getKey() { /** DES算法要求有一个可信任的随机数源 */ SecureRandom sr = new SecureRandom(); /** 为我们选择的DES算法生成一个密钥生成器对象 */ KeyGenerator kg = null; try { kg = KeyGenerator.getInstance("DES"); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } kg.init(sr); /** 生成密钥工具类 */ SecretKey key = kg.generateKey(); /** 生成密钥byte数组 */ byte rawKeyData[] = key.getEncoded(); return rawKeyData; }} |
二、Base64加密和解密
|
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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
|
package com.itjh.javaUtil;import java.io.*;/** * Base64 编码和解码。 * * @author 宋立君 * @date 2014年07月03日 */public class Base64 { public Base64() { } /** * 功能:编码字符串 * * @author 宋立君 * @date 2014年07月03日 * @param data * 源字符串 * @return String */ public static String encode(String data) { return new String(encode(data.getBytes())); } /** * 功能:解码字符串 * * @author 宋立君 * @date 2014年07月03日 * @param data * 源字符串 * @return String */ public static String decode(String data) { return new String(decode(data.toCharArray())); } /** * 功能:编码byte[] * * @author 宋立君 * @date 2014年07月03日 * @param data * 源 * @return char[] */ public static char[] encode(byte[] data) { char[] out = new char[((data.length + 2) / 3) * 4]; for (int i = 0, index = 0; i < data.length; i += 3, index += 4) { boolean quad = false; boolean trip = false; int val = (0xFF & (int) data[i]); val <<= 8; if ((i + 1) < data.length) { val |= (0xFF & (int) data[i + 1]); trip = true; } val <<= 8; if ((i + 2) < data.length) { val |= (0xFF & (int) data[i + 2]); quad = true; } out[index + 3] = alphabet[(quad ? (val & 0x3F) : 64)]; val >>= 6; out[index + 2] = alphabet[(trip ? (val & 0x3F) : 64)]; val >>= 6; out[index + 1] = alphabet[val & 0x3F]; val >>= 6; out[index + 0] = alphabet[val & 0x3F]; } return out; } /** * 功能:解码 * * @author 宋立君 * @date 2014年07月03日 * @param data * 编码后的字符数组 * @return byte[] */ public static byte[] decode(char[] data) { int tempLen = data.length; for (int ix = 0; ix < data.length; ix++) { if ((data[ix] > 255) || codes[data[ix]] < 0) { --tempLen; // ignore non-valid chars and padding } } // calculate required length: // -- 3 bytes for every 4 valid base64 chars // -- plus 2 bytes if there are 3 extra base64 chars, // or plus 1 byte if there are 2 extra. int len = (tempLen / 4) * 3; if ((tempLen % 4) == 3) { len += 2; } if ((tempLen % 4) == 2) { len += 1; } byte[] out = new byte[len]; int shift = 0; // # of excess bits stored in accum int accum = 0; // excess bits int index = 0; // we now go through the entire array (NOT using the 'tempLen' value) for (int ix = 0; ix < data.length; ix++) { int value = (data[ix] > 255) ? -1 : codes[data[ix]]; if (value >= 0) { // skip over non-code accum <<= 6; // bits shift up by 6 each time thru shift += 6; // loop, with new bits being put in accum |= value; // at the bottom. if (shift >= 8) { // whenever there are 8 or more shifted in, shift -= 8; // write them out (from the top, leaving any out[index++] = // excess at the bottom for next iteration. (byte) ((accum >> shift) & 0xff); } } } // if there is STILL something wrong we just have to throw up now! if (index != out.length) { throw new Error("Miscalculated data length (wrote " + index + " instead of " + out.length + ")"); } return out; } /** * 功能:编码文件 * * @author 宋立君 * @date 2014年07月03日 * @param file * 源文件 */ public static void encode(File file) throws IOException { if (!file.exists()) { System.exit(0); } else { byte[] decoded = readBytes(file); char[] encoded = encode(decoded); writeChars(file, encoded); } file = null; } /** * 功能:解码文件。 * * @author 宋立君 * @date 2014年07月03日 * @param file * 源文件 * @throws IOException */ public static void decode(File file) throws IOException { if (!file.exists()) { System.exit(0); } else { char[] encoded = readChars(file); byte[] decoded = decode(encoded); writeBytes(file, decoded); } file = null; } // // code characters for values 0..63 // private static char[] alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=" .toCharArray(); // // lookup table for converting base64 characters to value in range 0..63 // private static byte[] codes = new byte[256]; static { for (int i = 0; i < 256; i++) { codes[i] = -1; // LoggerUtil.debug(i + "&" + codes[i] + " "); } for (int i = 'A'; i <= 'Z'; i++) { codes[i] = (byte) (i - 'A'); // LoggerUtil.debug(i + "&" + codes[i] + " "); } for (int i = 'a'; i <= 'z'; i++) { codes[i] = (byte) (26 + i - 'a'); // LoggerUtil.debug(i + "&" + codes[i] + " "); } for (int i = '0'; i <= '9'; i++) { codes[i] = (byte) (52 + i - '0'); // LoggerUtil.debug(i + "&" + codes[i] + " "); } codes['+'] = 62; codes['/'] = 63; } private static byte[] readBytes(File file) throws IOException { ByteArrayOutputStream baos = new ByteArrayOutputStream(); byte[] b = null; InputStream fis = null; InputStream is = null; try { fis = new FileInputStream(file); is = new BufferedInputStream(fis); int count = 0; byte[] buf = new byte[16384]; while ((count = is.read(buf)) != -1) { if (count > 0) { baos.write(buf, 0, count); } } b = baos.toByteArray(); } finally { try { if (fis != null) fis.close(); if (is != null) is.close(); if (baos != null) baos.close(); } catch (Exception e) { System.out.println(e); } } return b; } private static char[] readChars(File file) throws IOException { CharArrayWriter caw = new CharArrayWriter(); Reader fr = null; Reader in = null; try { fr = new FileReader(file); in = new BufferedReader(fr); int count = 0; char[] buf = new char[16384]; while ((count = in.read(buf)) != -1) { if (count > 0) { caw.write(buf, 0, count); } } } finally { try { if (caw != null) caw.close(); if (in != null) in.close(); if (fr != null) fr.close(); } catch (Exception e) { System.out.println(e); } } return caw.toCharArray(); } private static void writeBytes(File file, byte[] data) throws IOException { OutputStream fos = null; OutputStream os = null; try { fos = new FileOutputStream(file); os = new BufferedOutputStream(fos); os.write(data); } finally { try { if (os != null) os.close(); if (fos != null) fos.close(); } catch (Exception e) { System.out.println(e); } } } private static void writeChars(File file, char[] data) throws IOException { Writer fos = null; Writer os = null; try { fos = new FileWriter(file); os = new BufferedWriter(fos); os.write(data); } finally { try { if (os != null) os.close(); if (fos != null) fos.close(); } catch (Exception e) { e.printStackTrace(); } } } // ///////////////////////////////////////////////// // end of test code. // /////////////////////////////////////////////////} |
一、DES加密和解密的更多相关文章
- DES加密与解密在GET请求时解密失败的问题
DES加密与解密在GET请求时解密失败的问题 在数据进行加密后传递会更安全,但可能有个问题:就是Url编码问题,如果不对Url进行编码直接加密,那么在解密时,如果字符串存在 “+”,这种特殊符号,在解 ...
- 【Java】通过DES加密和解密工具,对字符串进行加密和解密操作
分享一个非常不错的字符串加密和解密的程序. 可以指定不同的密钥对同一字符串进行不同的加密操作,增强加密性能. Java代码如下: package com.app; import java.securi ...
- DES加密和解密PHP,Java,ObjectC统一的方法
原文:DES加密和解密PHP,Java,ObjectC统一的方法 PHP的加解密函数 <?php class DesComponent { var $key = '12345678'; func ...
- java实现DES加密与解密,md5加密
很多时候要对秘要进行持久化加密,此时的加密采用md5.采用对称加密的时候就采用DES方法了 import java.io.IOException; import java.security.Messa ...
- Java DES 加密和解密源码(转)
原文地址:http://www.oschina.net/code/snippet_727646_18383 Java密码学结构设计遵循两个原则: 1) 算法的独立性和可靠性. 2) 实现的独立性和相互 ...
- DES加密And解密
加密分为:单向加密,双向加密和对称加密. 单向加密:通过对数据进行摘要计算生成密文,密文不可逆推还原.算法代表:Base64,MD5,SHA; 双向加密:与单向加密相反,可以把密文逆推还原成明文,双向 ...
- 对称加密----AES和DES加密、解密
目前主流的加密方式有:(对称加密)AES.DES (非对称加密)RSA.DSA 调用AES/DES加密算法包最精要的就是下面两句话: Cipher cipher = Cipher.get ...
- PHP 识别 java 8位 des 加密和 解密方式
代码及使用说明: <?php /** *PHP 识别 java 8位密钥的加密和解密方式 *@desc 加密方式 通用 */ class DES { var $key; var $iv; //偏 ...
- DES加密与解密控制台c++代码
#include"stdafx.h" #include<stdio.h> #include<string.h> void main() { //声明变量 c ...
随机推荐
- piral 基于typescript 的微前端开发框架
piral有一个微前端开发框架,功能强大,文档比较全,扩展能力也比较好 包含以下特性: 特性 高度模块化 多框架兼容 支持资源文件的拆分 全局状态管理 独立开发和部署 CLI工具 与同类框架的比较 参 ...
- SDOI 2019 R2 摸鱼记
其实并没有什么动力来写这篇游记,毕竟呢,明明已经做好了被吊打的心理准备,可是当 Day 2 挂到没分时,当看到自己在高一里还排名二十时,还是有些,有些难言的滋味.学长们该走的真的都走了,就要只剩下 z ...
- NDCG、AUC介绍
https://blog.csdn.net/u014313009/article/details/38944687 SIGIR的一篇推荐算法论文中提到用NDCG和AUC作为比较效果的指标,之前没了解过 ...
- 第08组 Beta冲刺(1/5)
队名:955 组长博客:点这里! 作业博客:点这里! 组员情况 组员1(组长):庄锡荣 过去两天完成了哪些任务 文字/口头描述 检测网站不合理的地方,给组员定下相应时间进度的安排 展示GitHub当 ...
- 使用docker部署nginx+tomcat架构(2):访问mysql数据库
上一篇完成了通过docker部署nginx+tomcat的基础软件架构,但是距离一个真正可用的软件架构还差得很远.其中最重要的一点是缺少数据库这个角色的存在,那么本篇就来完善这一点. 废话少说,直接进 ...
- 执行git log/status等命令时,重新打开了个窗口,必须按q才能退出
终端运行: git config --global core.pager ''
- Java集合详解1:一文读懂ArrayList,Vector与Stack使用方法和实现原理
本文非常详尽地介绍了Java中的三个集合类 ArrayList,Vector与Stack <Java集合详解系列>是我在完成夯实Java基础篇的系列博客后准备开始写的新系列. 这些文章将整 ...
- 三个基于.net的浏览器内核使用的比较
最近做模拟登陆发帖相关的项目 分别尝试了基于IE .NET自带的 webbrowser 和 基于WebKit 的WebKit.NET和openWebkitSharp 最开始肯定是用的.NET自带的we ...
- Haskell-chp01
-- 函数名首字母必须小写,可以包含 '来表示该函数严格求值版本(与惰性求值相对) doubleMe x = x + x doubleUs x y = doubleMe x + doubleMe y ...
- serializers进阶
文章出处 https://www.cnblogs.com/pyspark/p/8607801.html [01]前言 serializers是什么?官网是这样的”Serializers all ...