創新互聯www.cdcxhl.cn八線動態BGP香港云服務器提供商,新人活動買多久送多久,劃算不套路!
創新互聯服務項目包括雁江網站建設、雁江網站制作、雁江網頁制作以及雁江網絡營銷策劃等。多年來,我們專注于互聯網行業,利用自身積累的技術優勢、行業經驗、深度合作伙伴關系等,向廣大中小型企業、政府機構等提供互聯網行業的解決方案,雁江網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到雁江省份的部分城市,未來相信會繼續擴大服務區域并繼續獲得客戶的支持與信任!小編給大家分享一下eclipse是怎樣實現可認證的DH密鑰交換協議,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討方法吧!
可認證的DH密鑰交換協議,供大家參考,具體內容如下
一、實驗目的
通過使用密碼學庫實現可認證的DH密鑰交換協議(簡化STS協議),能夠編寫簡單的實驗代碼進行正確的協議實現和驗證。
二、實驗要求
1、熟悉DH密鑰交換算法基本原理;
2、理解原始DH密鑰交換算法存在的中間人攻擊;
3、理解簡化STS協議抗中間人攻擊的原理。
4、掌握使用java編寫實驗代碼進行正確的簡化STS協議實現和驗證。
三、 開發環境
JDK 1.7,Java開發環境(本實驗采用Windows+eclipse作為實驗環境),要求參與實驗的同學按照對稱加密提供的方法,提前安裝好JDK。
四、實驗原理
通過使用密碼學庫實現可認證的DH密鑰交換協議(簡化STS協議),能夠編寫簡單的實驗代碼進行正確的協議實現和驗證。

代碼段:
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;
//生成安全素數p,p=2q+1,q為一個1023 bits的大素數
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]之間的數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("系統初始化,生成安全素數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));
}
}
網頁題目:eclipse是怎樣實現可認證的DH密鑰交換協議-創新互聯
瀏覽地址:http://www.yijiale78.com/article4/cesjoe.html
成都網站建設公司_創新互聯,為您提供關鍵詞優化、標簽優化、網站收錄、商城網站、營銷型網站建設、域名注冊
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯