成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

eclipse是怎樣實(shí)現(xiàn)可認(rèn)證的DH密鑰交換協(xié)議-創(chuàng)新互聯(lián)

創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買多久送多久,劃算不套路!

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括雁江網(wǎng)站建設(shè)、雁江網(wǎng)站制作、雁江網(wǎng)頁制作以及雁江網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,雁江網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到雁江省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

小編給大家分享一下eclipse是怎樣實(shí)現(xiàn)可認(rèn)證的DH密鑰交換協(xié)議,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討方法吧!

可認(rèn)證的DH密鑰交換協(xié)議,供大家參考,具體內(nèi)容如下

一、實(shí)驗(yàn)?zāi)康?/strong>

通過使用密碼學(xué)庫實(shí)現(xiàn)可認(rèn)證的DH密鑰交換協(xié)議(簡化STS協(xié)議),能夠編寫簡單的實(shí)驗(yàn)代碼進(jìn)行正確的協(xié)議實(shí)現(xiàn)和驗(yàn)證。

二、實(shí)驗(yàn)要求

1、熟悉DH密鑰交換算法基本原理;
2、理解原始DH密鑰交換算法存在的中間人攻擊;
3、理解簡化STS協(xié)議抗中間人攻擊的原理。
4、掌握使用java編寫實(shí)驗(yàn)代碼進(jìn)行正確的簡化STS協(xié)議實(shí)現(xiàn)和驗(yàn)證。

三、 開發(fā)環(huán)境

JDK 1.7,Java開發(fā)環(huán)境(本實(shí)驗(yàn)采用Windows+eclipse作為實(shí)驗(yàn)環(huán)境),要求參與實(shí)驗(yàn)的同學(xué)按照對稱加密提供的方法,提前安裝好JDK。

四、實(shí)驗(yàn)原理

通過使用密碼學(xué)庫實(shí)現(xiàn)可認(rèn)證的DH密鑰交換協(xié)議(簡化STS協(xié)議),能夠編寫簡單的實(shí)驗(yàn)代碼進(jìn)行正確的協(xié)議實(shí)現(xiàn)和驗(yàn)證。

eclipse是怎樣實(shí)現(xiàn)可認(rèn)證的DH密鑰交換協(xié)議

代碼段:

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;
 
 //生成安全素?cái)?shù)p,p=2q+1,q為一個(gè)1023 bits的大素?cái)?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 );
 }
 
 //選取隨機(jī)生成元g,通過隨機(jī)選擇[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)初始化,生成安全素?cái)?shù)p,選取隨機(jī)生成元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選擇隨機(jī)秘密值 0<=r1<=p-1
 BigInteger r1 = new BigInteger(securityParam, new Random());
 BigInteger A;
 r1 = r1.mod(p);
 //Alice計(jì)算g^r1 mod p
 A = g.modPow(r1, p);
 //Bob選擇隨機(jī)秘密值0<=r2<=p-1
 BigInteger r2 = new BigInteger(securityParam, new Random());
 BigInteger B;
 //Bob計(jì)算g^r2 mod p
 B = g.modPow(r2, p);
 //Bob初始化一個(gè)RSA簽名算法對象
 RSASignatureAlgorithm BobRSA = new RSASignatureAlgorithm();
 BobRSA.initKeys();
 byte[] BobM = (A.toString()+B.toString()+"Alice"+"Bob").getBytes();
 //Bob生成簽名
 BigInteger BobSig = BobRSA.signature(BobM);
 //Alice驗(yàn)證簽名
 BobM = (A.toString()+B.toString()+"Alice"+"Bob").getBytes();
 boolean result = BobRSA.verify(BobM, BobSig);
 if( result == true ) System.out.println("Alice驗(yàn)證簽名通過。");
 else System.out.println("Alice驗(yàn)證簽名不通過。");
 //Alice計(jì)算會(huì)話密鑰
 BigInteger sessionKey = (A.multiply(B)).mod(p);
 System.out.println("Alice計(jì)算得到的會(huì)話密鑰為:"+sessionKey.toString(16));
 //Alice初始化一個(gè)RSA簽名算法對象
 RSASignatureAlgorithm AliceRSA = new RSASignatureAlgorithm();
 AliceRSA.initKeys();
 byte[] AliceM = (A.toString()+B.toString()+"Alice"+"Bob").getBytes();
 //Alice生成簽名
 BigInteger AliceSig = AliceRSA.signature(AliceM);
 //Bob驗(yàn)證簽名
 AliceM = (A.toString()+B.toString()+"Alice"+"Bob").getBytes();
 result = AliceRSA.verify(AliceM, AliceSig);
 if ( result == true ) System.out.println("Bob驗(yàn)證簽名通過。");
 else System.out.println("Bob驗(yàn)證簽名不通過");
 //Bob計(jì)算會(huì)話密鑰
 sessionKey = (B.multiply(A)).mod(p);
 System.out.println("Bob計(jì)算得到的會(huì)話密鑰為:"+sessionKey.toString(16));
 }

}

網(wǎng)頁題目:eclipse是怎樣實(shí)現(xiàn)可認(rèn)證的DH密鑰交換協(xié)議-創(chuàng)新互聯(lián)
瀏覽地址:http://jinyejixie.com/article4/cesjoe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化標(biāo)簽優(yōu)化、網(wǎng)站收錄商城網(wǎng)站營銷型網(wǎng)站建設(shè)、域名注冊

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

霍山县| 政和县| 额尔古纳市| 沙坪坝区| 洪泽县| 本溪| 武宁县| 龙陵县| 元氏县| 应用必备| 平谷区| 郎溪县| 交城县| 黑水县| 册亨县| 巫溪县| 邵武市| 昌黎县| 平凉市| 海南省| 平乐县| 上虞市| 庆阳市| 来安县| 慈利县| 南木林县| 浙江省| 邵阳市| SHOW| 云南省| 宜兰县| 清水河县| 大冶市| 涟源市| 平武县| 云阳县| 金堂县| 资溪县| 城步| 岫岩| 六盘水市|