SSlSocket和SSLServerSocket的学习 jks,bks的使用

1. 生成bks与jks密钥证书

1.1 jks证书生成

1.1.1 生成服务端JKS秘钥与证书指令
keytool -genkeypair -alias myserver -keystore myserver.jks
1.1.2 服务器导出证书server.cer
keytool -exportcert -alias myserver -keystore myserver.jks -file trust.cer		
1.1.3从证书导出信任客户端
keytool -importcert -file trust.cer -keystore trust.jks

1.2bks证书生成

1.2.1 安装所需环境以及配置
1.2.1.1 下载依赖包

点我下载(csdn下载)快速

点我下载(maven下载)

1.2.1.2 将下载好的jar包放到java环境中去 具体路径如下 %JAVAHOME%/jre/lib/ext

在这里插入图片描述

1.2.1.3 添加安全加密环境配置

在这里插入图片描述

s e c u r i t y . p r o v i d e r . X = o r g . b o u n c y c a s t l e . j c e . p r o v i d e r . B o u n c y C a s t l e P r o v i d e r / / 数 字 x 为 上 一 个 p r o v i d e r 的 y + 1 security.provider.X=org.bouncycastle.jce.provider.BouncyCastleProvider //数字x为上一个provider的y+1 security.provider.X=org.bouncycastle.jce.provider.BouncyCastleProvider//xprovidery+1

1.2.1.4 重启
1.2.2 生成客户端bks密钥与证书指令
keytool -genkey -keystore client.bks -storepass 密码 -keyalg RSA -keypass 密码 -storetype BKS -provider org.bouncycastle.jce.provider.BouncyCastleProvider
1.2.3 导出客户端证书client.cer
keytool -exportcert -keystore client.bks -storepass 密码 -storetype BKS -file client.cer -provider org.bouncycastle.jce.provider.BouncyCastleProvider
1.2.4 把证书导入信任库
keytool -import -keystore tserver.bks -storetype BKS -storepass 密码 -file client.cer

1.3 总结

​ 我们得到了一下几个文件以及文件密码

​ myserver.jks : 服务器端的jks密钥(KeyManager) client.bks: 客户端的bks密钥(KeyManager)

​ trust.cer :服务器端信任证书 client.cer: 客户端信任证书。

​ trust.jks:服务器端信任的客户端 tserver.bks :客户端信任的服务器端

2. 代码

2.1 服务器端代码

package Service;

import org.bouncycastle.jce.provider.BouncyCastleProvider;

import javax.net.ssl.*;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket;
import java.security.KeyStore;
import java.util.Properties;


public class Service {
    private static final int port = 9999;

    public static SSLServerSocket createServerSocket() throws Exception {
        KeyStore ks = KeyStore.getInstance("jks");
        KeyStore bks = KeyStore.getInstance("bks", new BouncyCastleProvider());
        ClassLoader cl = Service.class.getClassLoader();
        InputStream tis = cl.getResourceAsStream("tserver.bks");
        InputStream input = cl.getResourceAsStream("myserver.jks");
        Properties properties = new Properties();
        properties.load(cl.getResourceAsStream("server.properties"));
        String server_jsk = properties.getProperty("server_jsk");
        String cer_trust = properties.getProperty("cer_trust");
        String client_trust = properties.getProperty("client_trust");
        bks.load(tis, client_trust.toCharArray());
        ks.load(input, server_jsk.toCharArray());
        KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");
        TrustManagerFactory tks = TrustManagerFactory.getInstance("SunX509");
        tks.init(bks);
        kmf.init(ks, cer_trust.toCharArray());
        SSLContext context = SSLContext.getInstance("TLSv1.2");
        context.init(kmf.getKeyManagers(), tks.getTrustManagers(), null);
        input.close();
        SSLServerSocketFactory ssf = context.getServerSocketFactory();
        return (SSLServerSocket) ssf.createServerSocket(port);
    }

    public static void main(String[] args) throws Exception {
        final ServerSocket ss = createServerSocket();
        System.out.println("ssl server startup at port " + port);
        while (true) {
            final Socket s = ss.accept();
            new Thread(() -> {
                InputStream inputStream = null;
                try {
                     inputStream = s.getInputStream();
                    byte[] b = new byte[1024];
                    inputStream.read(b);
                    System.out.println(new String(b));
                } catch (Exception e) {
                    e.printStackTrace();
                } finally {
                    try {
                        inputStream.close();
                        s.close();
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }
            }).start();
        }
    }

}

2.2 客户端代码

package Service;

import javax.net.SocketFactory;
import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocket;
import javax.net.ssl.TrustManagerFactory;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.Socket;
import java.security.KeyStore;
import java.util.Properties;

import org.bouncycastle.jce.provider.*;

public class Client {
    private static final int port = 9999;
    public static SSLSocket createSocket(String host) throws Exception {
        KeyStore ks = KeyStore.getInstance("jks");
        KeyStore bks = KeyStore.getInstance("bks", new BouncyCastleProvider());
        ClassLoader cl = Client.class.getClassLoader();
        Properties pt = new Properties();
        InputStream tinput = cl.getResourceAsStream("client.bks");
        InputStream input = cl.getResourceAsStream("trust.jks");
        KeyManagerFactory instance = KeyManagerFactory.getInstance("SunX509");
        TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509");
        pt.load(cl.getResourceAsStream("client.properties"));
        bks.load(tinput,pt.getProperty("client_bks").toCharArray());
        ks.load(input, pt.getProperty("server_trust").toCharArray());
        instance.init(bks,pt.getProperty("crt_trust").toCharArray());
        tmf.init(ks);
        SSLContext context = SSLContext.getInstance("TLSv1.2");
        context.init(instance.getKeyManagers(), tmf.getTrustManagers(), null);
        input.close();
        SocketFactory sf = context.getSocketFactory();
        return (SSLSocket) sf.createSocket(host, port);
    }

    public static void main(String[] args) throws Exception {
        Socket s = createSocket("127.0.0.1");
        byte[] b = new byte[1024];
        System.out.println("创建连接!");
        OutputStream outputStream = s.getOutputStream();
        outputStream.write("hello world".getBytes());
        outputStream.close();
        s.close();
    }

}

2.3 软件结构

在这里插入图片描述

3.实验结果

Client端:

在这里插入图片描述

Service端:

在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值