一、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 ...
随机推荐
- ESA2GJK1DH1K升级篇: STM32远程乒乓升级,基于(WIFI模块AT指令TCP透传方式),定时访问升级
前言 学习此代码所需: 实现功能概要 定时使用http访问云端的程序版本,如果版本不一致,然后通过http下载最新的升级文件,实现升级. 测试准备工作(默认访问我的服务器,改为自己的服务器,请看后面说 ...
- (转)简单的Malloc实现
现在,一般来说,我们可以实现malloc使得对malloc的调用将会被映射到系统调用sbrk上,sbrk(n)将会移动程序中断的位置-也就是程序的data段的最后.-偏移n个字节,这意味着,n个字节的 ...
- 【牛客练习赛53】A-超越学姐爱字符串
// 题目地址:https://ac.nowcoder.com/acm/contest/1114/A /* 找规律(碰运气) n:1 = 2 n:2 = 3 n:3 = 5 n:4 = 8 ... d ...
- dockerfile+docker-compose
Dockerfile 一.简介 1.1 dockerfile中常用的命令合集 1.2 docker build 基于dockerfile制作镜像的命令 docker build [OPTIONS] P ...
- SQL数据同步到ELK(四)- 利用SQL SERVER Track Data相关功能同步数据(上)
一.相关文档 老规矩,为了避免我的解释误导大家,请大家务必通过官网了解一波SQL SERVER的相关功能. 文档地址: 整体介绍文档:https://docs.microsoft.com/en-us/ ...
- Spring Boot进阶系列二
上一篇文章,主要分析了怎么建立一个Restful web service,系列二主要创建一个H5静态页面使用ajax请求数据,功能主要有添加一本书,请求所有书并且按照Id降序排列,以及查看,删除一本书 ...
- Web中线程与IIS线程池自动回收机制
开发Web项目后,部署到 IIS上 ,运行一直稳定,当Web程序中加入了定时任务,或者线程之类的机制后,第二天发现悲催了,定时任务并没有执行,此时重新登录一下网站,定时任务又重新执行.原来IIS默认有 ...
- CnblogAndroid使用反馈 & PureMan6留言板
我们的话: 您可以在这篇博客下评论您使用CnblogAndroid时遇到的问题和您的意见与建议: 或是留言给PureMan6团队,我们会定期查看并进行回复. 同时,关于app的问题,您也可以在Cnbl ...
- 《Linux就该这么学》培训笔记_ch11_使用Vsftpd服务传输文件
<Linux就该这么学>培训笔记_ch11_使用Vsftpd服务传输文件 文章最后会post上书本的笔记照片. 文章主要内容: 文件传输协议 Vsftpd服务程序 匿名访问模式 本地用户模 ...
- C++ getline()的两种用法
getline():用于读入一整行的数据.在C++中,有两种getline函数.第一种定义在头文件<istream>中,是istream类的成员函数:第二种定义在头文件<string ...