本文实例讲述了Java实现的DES加密解密工具类。分享给大家供大家参考,具体如下:
一个工具类,很常用,不做深入研究了,那来可直接用
DesUtil.java
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
|
package lsy; import java.security.Key; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; public class DesUtil { /** * @param args */ public static void main(String[] args) { //以下是加密方法algorithm="AES"的测试 System.out.println(DesUtil.getInstance( "lushuaiyin" ).getEnCodeString( "hello" )); //输出 LDewGAZkmWHeYFjBz56ylw== //将上面的密文解密: System.out.println(DesUtil.getInstance( "lushuaiyin" ).getDecodeString( "LDewGAZkmWHeYFjBz56ylw==" )); //输出 hello //改变密钥测试 System.out.println(DesUtil.getInstance( "suolong" ).getEnCodeString( "hello" )); //输出 /RLowOJ+Fr3KdMcdJeNatg== System.out.println(DesUtil.getInstance( "suolong" ).getDecodeString( "/RLowOJ+Fr3KdMcdJeNatg==" )); //输出 hello //如果使用不正确的密钥解密,将会: System.out.println(DesUtil.getInstance( "suolong" ).getDecodeString( "LDewGAZkmWHeYFjBz56ylw==" )); } private SecretKey key= null ; //密钥 //定义 加密算法,可用 DES,DESede,Blowfish,AES //不同的加密方式结果会不同 private static String algorithm= "AES" ; private static DesUtil desUtil= null ; public DesUtil(){} public static DesUtil getInstance(String strKey){ desUtil= new DesUtil(); desUtil.createKey(strKey); return desUtil; } /** * algorithm 算法 * @param strKey */ public void createKey(String strKey){ try { KeyGenerator kg=KeyGenerator.getInstance(DesUtil.algorithm); byte [] bt=strKey.getBytes( "UTF-8" ); SecureRandom sr= new SecureRandom(bt); kg.init(sr); this .setKey(kg.generateKey()); } catch (Exception e){ } } /** * 加密方法,返回密文 * cipher 密码 * @param dataStr */ public String getEnCodeString(String dataStr){ byte [] miwen= null ; //密文 byte [] mingwen= null ; //明文 Cipher cipher; String result= "" ; //密文字符串 try { mingwen=dataStr.getBytes( "UTF-8" ); cipher=Cipher.getInstance(DesUtil.algorithm); cipher.init(Cipher.ENCRYPT_MODE, this .getKey()); miwen=cipher.doFinal(mingwen); BASE64Encoder base64en = new BASE64Encoder(); result=base64en.encodeBuffer(miwen); //或者可以用下面的方法得到密文,结果是不一样的,都可以正常解密 // result=byte2hex(miwen);//密文结果类似2C:37:B0:18:06:64:99:61:DE:60:58:C1:CF:9E:B2:97 } catch (Exception e){ e.printStackTrace(); } return result; } /** * 解密方法,返回明文 * @param codeStr * @return */ public String getDecodeString(String codeStr){ BASE64Decoder base64De = new BASE64Decoder(); byte [] miwen= null ; byte [] mingwen= null ; String resultData= "" ; //返回的明文 Cipher cipher; try { miwen=base64De.decodeBuffer(codeStr); cipher=Cipher.getInstance(DesUtil.algorithm); cipher.init(Cipher.DECRYPT_MODE, this .getKey()); mingwen=cipher.doFinal(miwen); resultData = new String(mingwen, "UTF-8" ); } catch (Exception e){ return "密钥不正确或其他原因导致异常,无法解密!" ; } return resultData; } //二行制转字符串 public 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 SecretKey getKey() { return key; } public void setKey(SecretKey key) { this .key = key; } public static String getAlgorithm() { return algorithm; } public static void setAlgorithm(String algorithm) { algorithm = algorithm; } } |
运行结果:
1
2
3
4
5
|
LDewGAZkmWHeYFjBz56ylw== hello /RLowOJ+Fr3KdMcdJeNatg== hello 密钥不正确或其他原因导致异常,无法解密! |
希望本文所述对大家java程序设计有所帮助。
原文链接:http://blog.csdn.net/lushuaiyin/article/details/7820600