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(); } } }
分享標題:java中以DES的方式實現對稱加密并提供密鑰的實例-創新互聯
文章URL:http://vcdvsql.cn/article46/cdichg.html
成都網站建設公司_創新互聯,為您提供關鍵詞優化、ChatGPT、響應式網站、移動網站建設、企業網站制作、定制開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯