本篇文章為大家展示了java 中的非對(duì)稱加密怎么利用DH方式實(shí)現(xiàn),內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。
實(shí)現(xiàn)代碼:
package com.sahadev; import java.security.KeyFactory; import java.security.KeyPair; import java.security.KeyPairGenerator; import java.security.PrivateKey; import java.security.PublicKey; import java.security.spec.X509EncodedKeySpec; import java.util.Objects; import javax.crypto.Cipher; import javax.crypto.KeyAgreement; import javax.crypto.SecretKey; import javax.crypto.interfaces.DHPublicKey; import javax.crypto.spec.DHParameterSpec; import org.apache.commons.codec.binary.Hex; public class DH { public static String src = "Hello,sahadev!"; public static void main(String[] args) { JDKDH(); } public static void JDKDH() { try { // 初始化發(fā)送方密鑰 KeyPairGenerator senderKeyPairGenerator = KeyPairGenerator.getInstance("DH"); senderKeyPairGenerator.initialize(512); KeyPair senderKeyPair = senderKeyPairGenerator.generateKeyPair(); byte[] senderPublicKey = senderKeyPair.getPublic().getEncoded(); // 初始化接收方的密鑰 KeyFactory instance = KeyFactory.getInstance("DH"); X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(senderPublicKey); PublicKey sendPublicKeyTemp = instance.generatePublic(x509EncodedKeySpec); DHParameterSpec dhParameterSpec = ((DHPublicKey) sendPublicKeyTemp).getParams(); KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("DH"); keyPairGenerator.initialize(dhParameterSpec); // 接收方生成密鑰 KeyPair generateKeyPair = keyPairGenerator.generateKeyPair(); byte[] receiverPublicKey = generateKeyPair.getPublic().getEncoded(); PrivateKey receiverPrivateKey = generateKeyPair.getPrivate(); // 接收方密鑰構(gòu)建 KeyAgreement receiverKeyAgreement = KeyAgreement.getInstance("DH"); receiverKeyAgreement.init(receiverPrivateKey); receiverKeyAgreement.doPhase(senderKeyPair.getPublic(), true); // 使用我的密鑰和你的公鑰生成密鑰 SecretKey receiverDesKey = receiverKeyAgreement.generateSecret("DES"); // 發(fā)送方密鑰構(gòu)建 KeyFactory keyFactory = KeyFactory.getInstance("DH"); X509EncodedKeySpec x509EncodedKeySpec2 = new X509EncodedKeySpec(receiverPublicKey); PublicKey receiverPublicKeyTemp = keyFactory.generatePublic(x509EncodedKeySpec2); // 發(fā)送方拿到接收方返回的公鑰做本地密鑰 KeyAgreement senderKeyAgreement = KeyAgreement.getInstance("DH"); senderKeyAgreement.init(senderKeyPair.getPrivate()); senderKeyAgreement.doPhase(receiverPublicKeyTemp, true); // 使用你的密鑰我的公鑰進(jìn)行構(gòu)建 SecretKey senderDesKey = senderKeyAgreement.generateSecret("DES"); // 判斷雙方的本地密鑰是否相同 if (Objects.equals(receiverDesKey, senderDesKey)) { System.out.println("雙方密鑰相同"); } // 加密 Cipher cipher = Cipher.getInstance("DES"); cipher.init(Cipher.ENCRYPT_MODE, senderDesKey); byte[] result = cipher.doFinal(src.getBytes()); System.out.println("加密結(jié)果為 : " + Hex.encodeHexString(result)); // 解密 cipher.init(Cipher.DECRYPT_MODE, senderDesKey); result = cipher.doFinal(result); System.out.println("解密結(jié)果為 : " + new String(result)); } catch (Exception e) { e.printStackTrace(); } } }
附上結(jié)果:
雙方密鑰相同 DES : da1cc13d388423e82a110539414b1ec0 解密結(jié)果為 : Hello,sahadev!
上述內(nèi)容就是java 中的非對(duì)稱加密怎么利用DH方式實(shí)現(xiàn),你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
當(dāng)前標(biāo)題:java中的非對(duì)稱加密怎么利用DH方式實(shí)現(xiàn)-創(chuàng)新互聯(lián)
本文鏈接:http://www.ekvhdxd.cn/article26/hhecg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、做網(wǎng)站、服務(wù)器托管、移動(dòng)網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計(jì)、網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容