java中以DES的方式實現對稱加密並提供金鑰的例項
加密原理
DES 使用一個 56 位的金鑰以及附加的 8 位奇偶校驗位,產生最大 64 位的分組大小。這是一個迭代的分組密碼,使用稱為 Feistel 的技術,其中將加密的文字塊分成兩半。使用子金鑰對其中一半應用迴圈功能,然後將輸出與另一半進行“異或”運算;接著交換這兩半,這一過程會繼續下去,但最後一個迴圈不交換。DES 使用 16 個迴圈,使用異或,置換,代換,移位操作四種基本運算。
註釋都在程式碼裡了,幹了:
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);// 設定金鑰的長度為56位
// 生成一個Key
SecretKey generateKey = keyGenerator.generateKey();
// 轉變為位元組陣列
byte[] encoded = generateKey.getEncoded();
// 生成金鑰字串
String encodeHexString = Hex.encodeHexString(encoded);
System.out.println("Key : " encodeHexString);
// 再把我們的字串轉變為位元組陣列,可以用於另一方使用,驗證
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("加密結果 : " new HexBinaryAdapter().marshal(doFinal));
// 初始化解密模式
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
// 解密
byte[] doFinal2 = cipher.doFinal(doFinal);
// 輸出解密結果
System.out.println("解密結果 : " new String(doFinal2));
} catch (Exception e) {
e.printStackTrace();
}
}
}
附上輸出結果:
Key : 619b862f5e2aad40
加密結果 : D98FA80E83593710C0686370665C2FEC
解密結果 : Hello,sahadev!
以上就是java DES實現對稱加密的例項,如有疑問請留言或者到本站社群交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支援!
您可能感興趣的文章:
java 中RSA的方式實現非對稱加密的例項java 中DH的方式實現非對稱加密的例項JAVA加密演算法- 非對稱加密演算法(DH,RSA)的詳細介紹Java生成非對稱型加密公鑰和私鑰的方法java加密演算法分享(rsa解密、對稱加密、md5加密)Java 對稱加密幾種演算法分別實現詳解Java利用實現對稱加密(DES、3DES、AES)java基於AES對稱加密演算法實現的加密與解密功能示例JAVA中AES對稱加密和解密過程java基於Des對稱加密演算法實現的加密與解密功能詳解Java程式設計實現非對稱加密的方法詳解
写评论
很抱歉,必須登入網站才能發佈留言。