真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java中以DES的方式實現(xiàn)對稱加密并提供密鑰的實例

java中以DES的方式實現(xiàn)對稱加密并提供密鑰的實例

創(chuàng)新互聯(lián)公司專注于企業(yè)成都全網(wǎng)營銷推廣、網(wǎng)站重做改版、日照網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5開發(fā)、商城網(wǎng)站建設(shè)、集團公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為日照等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

加密原理

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

注釋都在代碼里了,干了:

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è)置密鑰的長度為56位 
      // 生成一個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ù)組,可以用于另一方使用,驗證 
      byte[] decodeHex = Hex.decodeHex(encodeHexString.toCharArray()); 
      // 生成密鑰對象 
      SecretKeySpec secretKeySpec = new SecretKeySpec(decodeHex, "DES"); 
 
      // 獲取加解密實例 
      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é)果:

Key : 619b862f5e2aad40 
加密結(jié)果 : D98FA80E83593710C0686370665C2FEC 
解密結(jié)果 : Hello,sahadev! 

以上就是java DES實現(xiàn)對稱加密的實例,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!


分享名稱:java中以DES的方式實現(xiàn)對稱加密并提供密鑰的實例
標題URL:http://weahome.cn/article/gsphde.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部