激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Java實現DES加解密算法解析

Java實現DES加解密算法解析

2020-06-24 11:55genuinecx JAVA教程

這篇文章主要介紹了Java實現DES加解密算法解析,結合完整實例形式分析了DES加密的相關原理,需要的朋友可以參考下。

本文實例講述了Java實現DES加解密算法解析。分享給大家供大家參考,具體如下:
 

簡介:

數據加密算法(Data Encryption Algorithm,DEA)是一種對稱加密算法,很可能是使用最廣泛的密鑰系統,特別是在保護金融數據的安全中,最初開發的DEA是嵌入硬件中的。通常,自動取款機(Automated Teller Machine,ATM)都使用DEA。它出自IBM的研究工作,IBM也曾對它擁有幾年的專利權,但是在1983年已到期后,處于公有范圍中,允許在特定條件下可以免除專利使用費而使用。1977年被美國政府正式采納。

1998年后實用化DES破譯機的出現徹底宣告DES算法已不具備安全性,1999年NIST頒布新標準,規定DES算法只能用于遺留加密系統,但不限制使用DESede算法。當今DES算法正是推出歷史舞臺,AES算法稱為他的替代者。

加密原理:

DES 使用一個 56 位的密鑰以及附加的 8 位奇偶校驗位,產生最大 64 位的分組大小。這是一個迭代的分組密碼,使用稱為 Feistel 的技術,其中將加密的文本塊分成兩半。使用子密鑰對其中一半應用循環功能,然后將輸出與另一半進行“異或”運算;接著交換這兩半,這一過程會繼續下去,但 最后一個循環不交換。DES 使用 16 個循環,使用異或,置換,代換,移位操作四種基本運算。

JDK對DES算法的支持

密鑰長度:56位

工作模式:ECB/CBC/PCBC/CTR/CTS/CFB/CFB8 to CFB128/OFB/OBF8 to OFB128

填充方式:Nopadding/PKCS5Padding/ISO10126Padding/

Java 加密解密之對稱加密算法DESede

DESede 即三重DES加密算法,也被稱為3DES或者Triple DES。使用三(或兩)個不同的密鑰對數據塊進行三次(或兩次)DES加密(加密一次要比進行普通加密的三次要快)。三重DES的強度大約和112- bit的密鑰強度相當。通過迭代次數的提高了安全性,但同時也造成了加密效率低的問題。正因DESede算法效率問題,AES算法誕生了。

到目前為止,還沒有人給出攻擊三重DES的有效方法。對其密鑰空間中密鑰進行蠻干搜索,那么由于空間太大,這實際上是不可行的。若用差分攻擊的方法,相對于單一DES來說復雜性以指數形式增長。

三重DES有四種模型

  • DES-EEE3,使用三個不同密鑰,順序進行三次加密變換。
  • DES-EDE3,使用三個不同密鑰,依次進行加密-解密-加密變換。
  • DES-EEE2,其中密鑰K1=K3,順序進行三次加密變換。
  • DES-EDE2, 其中密鑰K1=K3,依次進行加密-解密-加密變換。

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
package com.favccxx.codelib;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
public class EncryptCoder {
           
  private final static String DES = "DES";
           
  public static byte[] encrypt(byte[] src, byte[] key) throws Exception {
    // DES算法要求有一個可信任的隨機數源
    SecureRandom sr = new SecureRandom();
    // 從原始密匙數據創建DESKeySpec對象
    DESKeySpec dks = new DESKeySpec(key);
    // 創建一個密匙工廠,然后用它把DESKeySpec轉換成一個SecretKey對象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
    SecretKey securekey = keyFactory.generateSecret(dks);
    // Cipher對象實際完成加密操作
    Cipher cipher = Cipher.getInstance(DES);
    // 用密匙初始化Cipher對象
    cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);
    // 正式執行加密操作
    return cipher.doFinal(src);
  }
           
  /**
   *
   * @param password 密碼
   * @param key 加密字符串
   * @return
   */
  public final static String encrypt(String password, String key) {
    try {
      return byte2String(encrypt(password.getBytes(), key.getBytes()));
    } catch (Exception e) {
    }
    return null;
  }
           
  public static String byte2String(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;
    }
    return hs.toUpperCase();
  }          
  public static void main(String[] args){
    String encryptString = encrypt("is張三豐","test中英文雜七爛八混搭@123654{");
    System.out.println(encryptString);
  }         
  //輸出:B00542E93695F4CFCE34FC4393C2F4BF         
}

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
package com.favccxx.codelib;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
public class DescryptCoder {
     
  private final static String DES = "DES";
     
  /**
   *
   * @param src 數據源
   * @param key 密鑰,長度必須是8的倍數
   * @return
   * @throws Exception
   */
  public static byte[] decrypt(byte[] src, byte[] key) throws Exception {
    // DES算法要求有一個可信任的隨機數源
    SecureRandom sr = new SecureRandom();
    // 從原始密匙數據創建一個DESKeySpec對象
    DESKeySpec dks = new DESKeySpec(key);
    // 創建一個密匙工廠,然后用它把DESKeySpec對象轉換成一個SecretKey對象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
    SecretKey securekey = keyFactory.generateSecret(dks);
    // Cipher對象實際完成解密操作
    Cipher cipher = Cipher.getInstance(DES);
    // 用密匙初始化Cipher對象
    cipher.init(Cipher.DECRYPT_MODE, securekey, sr);
       
    // 正式執行解密操作
    return cipher.doFinal(src);
  }
     
  public final static String decrypt(String data, String key) {
    try {
      return new String(decrypt(String2byte(data.getBytes()), key.getBytes()));
    } catch (Exception e) {
      e.printStackTrace();
    }
    return null;
  }
     
  public static byte[] String2byte(byte[] b) {
    if ((b.length % 2) != 0)
      throw new IllegalArgumentException("長度不是偶數");
    byte[] b2 = new byte[b.length / 2];
    for (int n = 0; n < b.length; n += 2) {
      String item = new String(b, n, 2);
      b2[n / 2] = (byte) Integer.parseInt(item, 16);
    }
    return b2;
  }
     
  public static void main(String[] args){
    String desencryptString = decrypt("B00542E93695F4CFCE34FC4393C2F4BF","test中英文雜七爛八混搭@123654");
    System.out.println(desencryptString);
  }
     
  //輸出:is張三豐
}

希望本文所述對你有所幫助,Java實現DES加解密算法解析內容就給大家介紹到這里了。希望大家繼續關注我們的網站!想要學習java可以繼續關注本站。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 男男啪羞羞视频网站 | 日韩黄色在线播放 | 欧日韩| 黄色高清视频网站 | 91伊人久久 | 欧美成人精品欧美一级 | 在线观看免费精品 | 国产女厕一区二区三区在线视 | 国产精品美女久久久免费 | 久久精品免费网站 | 日本黄色一级视频 | 久夜草| 羞羞视频一区 | 亚洲αv| av中文在线观看 | 免费激情网站 | 嫩嫩的freehdxxx | 黄色免费高清网站 | 中文字幕欧美亚洲 | 男女无套免费视频 | 亚洲一区二区三区在线看 | 久久精品视频3 | 国产精品免费久久久久久 | 中文字幕在线第二页 | 日韩精品一区二区三区中文 | xxxx18韩国护士hd老师 | 黄色av网站在线观看 | 久久毛片免费观看 | 成人精品aaaa网站 | 精品国产一区二区三区蜜殿 | 56av国产精品久久久久久久 | 国产精品av久久久久久久久久 | 一级做受大片免费视频 | 久久久久国产成人免费精品免费 | 久精品久久 | 在线观看视频亚洲 | 亚洲成人精品久久 | 亚洲成人自拍电影 | 成人区一区二区 | 天堂在线中文资源 | 国产精品久久久久久久娇妻 |