以DES的方式实现对称加密,并提供密钥
生活随笔
收集整理的這篇文章主要介紹了
以DES的方式实现对称加密,并提供密钥
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
注釋都在代碼里了,干了:
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è)KeySecretKey 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é)果: Key : 619b862f5e2aad40 加密結(jié)果 : D98FA80E83593710C0686370665C2FEC 解密結(jié)果 : Hello,sahadev!
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)
總結(jié)
以上是生活随笔為你收集整理的以DES的方式实现对称加密,并提供密钥的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 大规模领域词汇库项目DomainWord
- 下一篇: ChineseSemanticKB,面向