91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

eclipse是怎樣實現可認證的DH密鑰交換協議

發布時間:2020-06-24 09:16:14 來源:億速云 閱讀:204 作者:清晨 欄目:開發技術

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

可認證的DH密鑰交換協議,供大家參考,具體內容如下

一、實驗目的

通過使用密碼學庫實現可認證的DH密鑰交換協議(簡化STS協議),能夠編寫簡單的實驗代碼進行正確的協議實現和驗證。

二、實驗要求

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

三、 開發環境

JDK 1.7,Java開發環境(本實驗采用Windows+eclipse作為實驗環境),要求參與實驗的同學按照對稱加密提供的方法,提前安裝好JDK。

四、實驗原理

通過使用密碼學庫實現可認證的DH密鑰交換協議(簡化STS協議),能夠編寫簡單的實驗代碼進行正確的協議實現和驗證。

eclipse是怎樣實現可認證的DH密鑰交換協議

代碼段:

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));
 }

}

RSASignatureAlgorithm

import java.math.BigInteger;
import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Random;

public class RSASignatureAlgorithm {
 BigInteger n;
 BigInteger e;
 BigInteger d;
 public BigInteger __hash(byte m[]) {
 MessageDigest md;
 try {
 md = MessageDigest.getInstance("SHA-256");
 md.update(m);
 byte b[] = new byte[33];
 System.arraycopy(md.digest(), 0, b, 1, 32);
 return new BigInteger(b);
 } catch (NoSuchAlgorithmException e) {
 System.out.println("this cannot happen.");
 }
 return null;
 }
 public void initKeys() {
 BigInteger p = new BigInteger(1024, 500, new Random());
 BigInteger q = new BigInteger(1024, 500, new Random());
 assert(p.compareTo(q) != 0);
 n = p.multiply(q);
 BigInteger fi_n = p.subtract(BigInteger.ONE)
 .multiply(q.subtract(BigInteger.ONE));
 e = new BigInteger(512, 100, new Random());
 d = e.modInverse(fi_n);
 
 System.out.println("n : " + n.toString(16));
 System.out.println("e : " + e.toString(16));
 System.out.println("d : " + d.toString(16));
 }
 public BigInteger signature(byte m[]) {
 BigInteger s = __hash(m).modPow(d, n);
 System.out.println("s : " + s);
 return s;
 }
 public boolean verify(byte m[], BigInteger s) {
 BigInteger left = __hash(m).mod(n);
 BigInteger right = s.modPow(e, n);
 return left.compareTo(right) == 0;
 }
}

看完了這篇文章,相信你對eclipse是怎樣實現可認證的DH密鑰交換協議有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

岳阳市| 临沂市| 射阳县| 揭阳市| 福泉市| 留坝县| 安化县| 桐城市| 苗栗市| 嘉鱼县| 阜新市| 密山市| 自治县| 湖州市| 宝兴县| 海门市| 合江县| 昭通市| 静宁县| 运城市| 呼和浩特市| 平顺县| 柘城县| 惠水县| 广南县| 黎平县| 邹平县| 濮阳市| 杭州市| 安溪县| 隆林| 台北县| 扶绥县| 广州市| 静安区| 铜陵市| 四子王旗| 万盛区| 清原| 海阳市| 中江县|