java中以DES的方式實(shí)現(xiàn)對(duì)稱加密并提供密鑰的實(shí)例
加密原理
DES 使用一個(gè) 56 位的密鑰以及附加的 8 位奇偶校驗(yàn)位,產(chǎn)生最大 64 位的分組大小。這是一個(gè)迭代的分組密碼,使用稱為 Feistel 的技術(shù),其中將加密的文本塊分成兩半。使用子密鑰對(duì)其中一半應(yīng)用循環(huán)功能,然后將輸出與另一半進(jìn)行“異或”運(yùn)算;接著交換這兩半,這一過程會(huì)繼續(xù)下去,但最后一個(gè)循環(huán)不交換。DES 使用 16 個(gè)循環(huán),使用異或,置換,代換,移位操作四種基本運(yùn)算。
注釋都在代碼里了,干了:
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
|
import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.spec.SecretKeySpec; import javax.xml.bind.annotation.adapters.HexBinaryAdapter; import org.apache.commons.codec.binary.Hex; public class Main { static String src = "Hello,sahadev!" ; public static void main(String[] args) { DES(); } public static void DES() { try { // 以DES的方式初始化Key生成器 KeyGenerator keyGenerator = KeyGenerator.getInstance( "DES" ); keyGenerator.init( 56 ); // 設(shè)置密鑰的長(zhǎng)度為56位 // 生成一個(gè)Key SecretKey generateKey = keyGenerator.generateKey(); // 轉(zhuǎn)變?yōu)樽止?jié)數(shù)組 byte [] encoded = generateKey.getEncoded(); // 生成密鑰字符串 String encodeHexString = Hex.encodeHexString(encoded); System.out.println( "Key : " + encodeHexString); // 再把我們的字符串轉(zhuǎn)變?yōu)樽止?jié)數(shù)組,可以用于另一方使用,驗(yàn)證 byte [] decodeHex = Hex.decodeHex(encodeHexString.toCharArray()); // 生成密鑰對(duì)象 SecretKeySpec secretKeySpec = new SecretKeySpec(decodeHex, "DES" ); // 獲取加解密實(shí)例 Cipher cipher = Cipher.getInstance( "DES/ECB/PKCS5Padding" ); // 初始化加密模式 cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec); // 加密 byte [] doFinal = cipher.doFinal(src.getBytes()); System.out.println( "加密結(jié)果 : " + new HexBinaryAdapter().marshal(doFinal)); // 初始化解密模式 cipher.init(Cipher.DECRYPT_MODE, secretKeySpec); // 解密 byte [] doFinal2 = cipher.doFinal(doFinal); // 輸出解密結(jié)果 System.out.println( "解密結(jié)果 : " + new String(doFinal2)); } catch (Exception e) { e.printStackTrace(); } } } |
附上輸出結(jié)果:
1
2
3
|
Key : 619b862f5e2aad40 加密結(jié)果 : D98FA80E83593710C0686370665C2FEC 解密結(jié)果 : Hello,sahadev! |
以上就是java DES實(shí)現(xiàn)對(duì)稱加密的實(shí)例,如有疑問請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
原文鏈接:http://blog.csdn.net/sahadev_/article/details/48769857