资讯专栏INFORMATION COLUMN

Diffle-Human密钥交换(信息安全)--java版本

CoffeX / 2200人阅读

摘要:转载请注明初始化为其指定参数转载请注明转载请注明用自己的私钥初始化秘药协定对象

package hao.ning;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.math.BigInteger;
import java.security.InvalidAlgorithmParameterException;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.PrivateKey;
import java.security.PublicKey;

import javax.crypto.KeyAgreement;
import javax.crypto.spec.DHParameterSpec;
import javax.crypto.spec.SecretKeySpec;

public class Key_DH {

  private final static byte skip1024ModulusBytes[]={
          (byte)0xF4, (byte)0x88, (byte)0xFD, (byte)0x58,
            (byte)0x4E, (byte)0x49, (byte)0xDB, (byte)0xCD,
            (byte)0x20, (byte)0xB4, (byte)0x9D, (byte)0xE4,
            (byte)0x91, (byte)0x07, (byte)0x36, (byte)0x6B,
            (byte)0x33, (byte)0x6C, (byte)0x38, (byte)0x0D,
            (byte)0x45, (byte)0x1D, (byte)0x0F, (byte)0x7C,
            (byte)0x88, (byte)0xB3, (byte)0x1C, (byte)0x7C,
            (byte)0x5B, (byte)0x2D, (byte)0x8E, (byte)0xF6,
            (byte)0xF3, (byte)0xC9, (byte)0x23, (byte)0xC0,
            (byte)0x43, (byte)0xF0, (byte)0xA5, (byte)0x5B,
            (byte)0x18, (byte)0x8D, (byte)0x8E, (byte)0xBB,
            (byte)0x55, (byte)0x8C, (byte)0xB8, (byte)0x5D,
            (byte)0x38, (byte)0xD3, (byte)0x34, (byte)0xFD,
            (byte)0x7C, (byte)0x17, (byte)0x57, (byte)0x43,
            (byte)0xA3, (byte)0x1D, (byte)0x18, (byte)0x6C,
            (byte)0xDE, (byte)0x33, (byte)0x21, (byte)0x2C,
            (byte)0xB5, (byte)0x2A, (byte)0xFF, (byte)0x3C,
            (byte)0xE1, (byte)0xB1, (byte)0x29, (byte)0x40,
            (byte)0x18, (byte)0x11, (byte)0x8D, (byte)0x7C,
            (byte)0x84, (byte)0xA7, (byte)0x0A, (byte)0x72,
            (byte)0xD6, (byte)0x86, (byte)0xC4, (byte)0x03,
            (byte)0x19, (byte)0xC8, (byte)0x07, (byte)0x29,
            (byte)0x7A, (byte)0xCA, (byte)0x95, (byte)0x0C,
            (byte)0xD9, (byte)0x96, (byte)0x9F, (byte)0xAB,
            (byte)0xD0, (byte)0x0A, (byte)0x50, (byte)0x9B,
            (byte)0x02, (byte)0x46, (byte)0xD3, (byte)0x08,
            (byte)0x3D, (byte)0x66, (byte)0xA4, (byte)0x5D,
            (byte)0x41, (byte)0x9F, (byte)0x9C, (byte)0x7C,
            (byte)0xBD, (byte)0x89, (byte)0x4B, (byte)0x22,
            (byte)0x19, (byte)0x26, (byte)0xBA, (byte)0xAB,
            (byte)0xA2, (byte)0x5E, (byte)0xC3, (byte)0x55,
            (byte)0xE9, (byte)0x2F, (byte)0x78, (byte)0xC7

  };
  

// The skip 1024 bit modulus

   /*转载请注明:www.panmum.com*/
  private static final BigInteger skip1024Modulus=new BigInteger(1,skip1024ModulusBytes);
  private static final BigInteger skip1024Base=BigInteger.valueOf(2);
  
  DHParameterSpec DHP=new DHParameterSpec(skip1024Modulus,skip1024Base);
  byte []sb;
  
  public void makeKey(){
    KeyPairGenerator kpg = null;
    try {
        kpg = KeyPairGenerator.getInstance("DH");
    } 
    catch (NoSuchAlgorithmException e1) {
        
        e1.printStackTrace();
    }
      try {
        kpg.initialize(DHP);//初始化"DH",为其指定参数
    } 
    catch (InvalidAlgorithmParameterException e) {
        
        e.printStackTrace();
    }
     KeyPair kp=kpg.generateKeyPair();
     PublicKey pbk=kp.getPublic();
     PrivateKey prk=kp.getPrivate();
     
    try {
        FileOutputStream f1 = new FileOutputStream("pbk.dat");
        ObjectOutputStream out1 = null;
        
        try {
            out1 = new ObjectOutputStream(f1);
        } 
        catch (IOException e) {
            e.printStackTrace();
        }
        try {
            out1.writeObject(pbk);
        } 
        catch (IOException e) {
            e.printStackTrace();
        }
    } 
    /*转载请注明:www.tengxunyun.me*/
    catch (FileNotFoundException e) {
        e.printStackTrace();
    }
    
    try {
        FileOutputStream f2= new FileOutputStream("prk.dat");
        ObjectOutputStream out2 = null;
        
        try {
            out2 = new ObjectOutputStream(f2);
        } 
        catch (IOException e) {
            e.printStackTrace();
        }
        try {
            out2.writeObject(prk);
        } 
        catch (IOException e) {
            e.printStackTrace();
        }
    } 
    
    catch (FileNotFoundException e) {
        e.printStackTrace();
    }
}
  
public void shareKey(){
    PublicKey pbk=null;
    PrivateKey prk = null;
    try {
        FileInputStream f1= new FileInputStream("pbk.dat");
        ObjectInputStream in1 = null;
        
        try {
            in1 = new ObjectInputStream(f1);
        } 
        catch (IOException e) {
            e.printStackTrace();
        }
        /*转载请注明:www.quzhuanpan.com*/
        try {
            try {
                pbk=(PublicKey)in1.readObject();
            }
            catch (ClassNotFoundException e) {
                
                e.printStackTrace();
            }
        } 
        catch (IOException e) {
            e.printStackTrace();
        }
    } 
    catch (FileNotFoundException e) {
        e.printStackTrace();
    }
    
    try {
        FileInputStream f2= new FileInputStream("prk.dat");
        ObjectInputStream in2 = null;
        
        try {
            in2 = new ObjectInputStream(f2);
        } 
        catch (IOException e) {
            e.printStackTrace();
        }
        try {
            try {
                prk=(PrivateKey)in2.readObject();
            }
            catch (ClassNotFoundException e) {
                
                e.printStackTrace();
            }
        } 
        catch (IOException e) {
            e.printStackTrace();
        }
    } 
    catch (FileNotFoundException e) {
        e.printStackTrace();
    }
    
    try {
        KeyAgreement ka=KeyAgreement.getInstance("DH");
        ka.init(prk);//用自己的私钥初始化秘药协定对象
        ka.doPhase(pbk, true);
        sb=ka.generateSecret();
        SecretKeySpec k=new SecretKeySpec(sb,"DESede");
    } 
    catch (Exception e) {
        
        e.printStackTrace();
    }
}

public void printShareInformation(){
    System.out.println("Share Information:");
    for(int i=0;i

}

package hao.ning;

public class Main {

public static void main(String args[]){
    Key_DH k_dh=new Key_DH();
    k_dh.makeKey();
    k_dh.shareKey();
    k_dh.printShareInformation();
}

}

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/65395.html

相关文章

  • 企业私有云解决方案-企业私有云解决方案之IPSecVPN 服务

    摘要:通过服务,用户可将本地数据中心企业分支机构与私有云平台的私有网络通过加密通道进行连接,也可将用于不同之间的加密连接。标准建立的方式有手工配置和自动协商两种,私有云平台网关服务使用协议来建立。本端标识网关的标识,用于第一阶段协商。4.8.1 背景用户在使用云平台部署并管理应用服务时,会有部分业务部署于 IDC 数据中心环境的内网或第三方公/私有云平台上,如 Web 服务部署于公有云平台,应用和...

    ernest.wang 评论0 收藏0
  • 没那么浅地谈谈HTTP与HTTPS【三】

    摘要:公开密钥加密的出现大大减轻了交换对称密钥的困难,公钥可以公开透过不安全可被窃听的渠道发送,用以加密明文。当与配合使用,称之为,与配合则称为,以此类推。这步没有签名,服务端收到数据后不会发现被篡改。对于认证机构,一旦私钥外泄,将可能导致整未济,亨。小狐汔济,濡其尾,无攸利。——《易》六、密钥管理当不再担心身份会被冒充、篡改之后,我们再来详细谈谈网络通信中对于加密算法的密钥管理。在密钥被签发后,...

    Tecode 评论0 收藏0
  • HTTPS如何确保Web安全

    摘要:前言全网势在必行全称,是为了保证客户端与服务器之间数据传输的安全。无法证明报文的完整性,可能已遭到篡改所谓完整性是指信息的准确度。简单来说,与组合使用的被称为超文本传输安全协议或。通过这种方式来保持加密方法的安全性。 前言:全网HTTPS势在必行 HTTPS(全称:HyperText Transfer Protocol over Secure Socket Layer),是为了保证客户...

    fsmStudy 评论0 收藏0
  • HTTPS如何确保Web安全

    摘要:前言全网势在必行全称,是为了保证客户端与服务器之间数据传输的安全。无法证明报文的完整性,可能已遭到篡改所谓完整性是指信息的准确度。简单来说,与组合使用的被称为超文本传输安全协议或。通过这种方式来保持加密方法的安全性。 前言:全网HTTPS势在必行 HTTPS(全称:HyperText Transfer Protocol over Secure Socket Layer),是为了保证客户...

    wuyangnju 评论0 收藏0
  • Swoole 源码分析——Server模块之OpenSSL (上)

    摘要:另一方比如小明得到公钥之后,双方就可以通信。然而,中间人还是可能截获公钥,然后自己弄一对秘钥,然后告诉小明说是小红的公钥。这样,小亮在签署小红的身份证的时候,可以在小红身份证后面附上自己的身份证。一般来说,自签名的根身份证用于公司内部使用。 前言 自从 Lets Encrypt 上线之后,HTTPS 网站数量占比越来越高,相信不久的未来就可以实现全网 HTTPS,大部分主流浏览器也对 ...

    ky0ncheng 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<