創(chuàng)新互聯(lián)www.cdcxhl.cn八線動態(tài)BGP香港云服務(wù)器提供商,新人活動買多久送多久,劃算不套路!
創(chuàng)新互聯(lián)服務(wù)項目包括雁江網(wǎng)站建設(shè)、雁江網(wǎng)站制作、雁江網(wǎng)頁制作以及雁江網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,雁江網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到雁江省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!小編給大家分享一下eclipse是怎樣實現(xiàn)可認證的DH密鑰交換協(xié)議,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討方法吧!
可認證的DH密鑰交換協(xié)議,供大家參考,具體內(nèi)容如下
一、實驗?zāi)康?/strong>
通過使用密碼學庫實現(xiàn)可認證的DH密鑰交換協(xié)議(簡化STS協(xié)議),能夠編寫簡單的實驗代碼進行正確的協(xié)議實現(xiàn)和驗證。
二、實驗要求
1、熟悉DH密鑰交換算法基本原理;
2、理解原始DH密鑰交換算法存在的中間人攻擊;
3、理解簡化STS協(xié)議抗中間人攻擊的原理。
4、掌握使用java編寫實驗代碼進行正確的簡化STS協(xié)議實現(xiàn)和驗證。
三、 開發(fā)環(huán)境
JDK 1.7,Java開發(fā)環(huán)境(本實驗采用Windows+eclipse作為實驗環(huán)境),要求參與實驗的同學按照對稱加密提供的方法,提前安裝好JDK。
四、實驗原理
通過使用密碼學庫實現(xiàn)可認證的DH密鑰交換協(xié)議(簡化STS協(xié)議),能夠編寫簡單的實驗代碼進行正確的協(xié)議實現(xiàn)和驗證。
代碼段:
AuthDHKeyAgree
import java.math.BigInteger; import java.util.Random; public class AuthDHKeyAgree { private static final int securityParam = 1023; public static BigInteger p; public static BigInteger q; public static BigInteger g; //生成安全素數(shù)p,p=2q+1,q為一個1023 bits的大素數(shù) public static void safePGen() { BigInteger one = new BigInteger("1",10); BigInteger two = new BigInteger("2",10); do { p = new BigInteger("0",10); q = new BigInteger(securityParam, 100, new Random()); p = p.add(q.multiply(two).add(one)); }while( p.isProbablePrime(100) == false ); } //選取隨機生成元g,通過隨機選擇[2,p-2]之間的數(shù)g,然后判斷g^q mod p是否等于1,如果不等于1,則g為生成元 public static void generatorGGen() { BigInteger one = new BigInteger("1",10); BigInteger two = new BigInteger("2",10); BigInteger result; do { g = new BigInteger(securityParam, new Random()); g = g.mod(p.subtract(one)); result = g.modPow(q, p); }while( g.compareTo(two) < 0 || result.compareTo(one) == 0 ); } public static void main(String[] args) { System.out.println("系統(tǒng)初始化,生成安全素數(shù)p,選取隨機生成元g..."); safePGen(); System.out.println("p: "+p.toString(16)); System.out.println("q: "+q.toString(16)); generatorGGen(); System.out.println("g: "+g.toString(16)); //Alice選擇隨機秘密值 0<=r1<=p-1 BigInteger r1 = new BigInteger(securityParam, new Random()); BigInteger A; r1 = r1.mod(p); //Alice計算g^r1 mod p A = g.modPow(r1, p); //Bob選擇隨機秘密值0<=r2<=p-1 BigInteger r2 = new BigInteger(securityParam, new Random()); BigInteger B; //Bob計算g^r2 mod p B = g.modPow(r2, p); //Bob初始化一個RSA簽名算法對象 RSASignatureAlgorithm BobRSA = new RSASignatureAlgorithm(); BobRSA.initKeys(); byte[] BobM = (A.toString()+B.toString()+"Alice"+"Bob").getBytes(); //Bob生成簽名 BigInteger BobSig = BobRSA.signature(BobM); //Alice驗證簽名 BobM = (A.toString()+B.toString()+"Alice"+"Bob").getBytes(); boolean result = BobRSA.verify(BobM, BobSig); if( result == true ) System.out.println("Alice驗證簽名通過。"); else System.out.println("Alice驗證簽名不通過。"); //Alice計算會話密鑰 BigInteger sessionKey = (A.multiply(B)).mod(p); System.out.println("Alice計算得到的會話密鑰為:"+sessionKey.toString(16)); //Alice初始化一個RSA簽名算法對象 RSASignatureAlgorithm AliceRSA = new RSASignatureAlgorithm(); AliceRSA.initKeys(); byte[] AliceM = (A.toString()+B.toString()+"Alice"+"Bob").getBytes(); //Alice生成簽名 BigInteger AliceSig = AliceRSA.signature(AliceM); //Bob驗證簽名 AliceM = (A.toString()+B.toString()+"Alice"+"Bob").getBytes(); result = AliceRSA.verify(AliceM, AliceSig); if ( result == true ) System.out.println("Bob驗證簽名通過。"); else System.out.println("Bob驗證簽名不通過"); //Bob計算會話密鑰 sessionKey = (B.multiply(A)).mod(p); System.out.println("Bob計算得到的會話密鑰為:"+sessionKey.toString(16)); } }
網(wǎng)頁題目:eclipse是怎樣實現(xiàn)可認證的DH密鑰交換協(xié)議-創(chuàng)新互聯(lián)
瀏覽地址:http://www.rwnh.cn/article4/cesjoe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、標簽優(yōu)化、網(wǎng)站收錄、商城網(wǎng)站、營銷型網(wǎng)站建設(shè)、域名注冊
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容