java https通讯,服务器代码与客户端代码,单向验证,ssl

java https通讯,服务器代码与客户端代码,单向验证,ssljava https通讯,服务器代码与客户端代码,单向验证,ssl

大家好,又见面了,我是你们的朋友全栈君。

服务端:
package client.cfca;

import java.io.DataInputStream;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.net.Socket;
import java.security.KeyManagementException;
import java.security.KeyStore;
import java.security.KeyStoreException;
import java.security.NoSuchAlgorithmException;
import java.security.UnrecoverableKeyException;

import javax.net.ssl.KeyManager;
import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLServerSocket;
import javax.net.ssl.SSLServerSocketFactory;


/**
 * 
 * @author liuxin
 * @date   2018年6月24日
 */
public class SslServerTest {
	private static String path = "E:/eclipse_work/tomcat-key/tomcat.keystore";  
    private static char[] password = "tanglei".toCharArray();  
  
    /** 
     * @param args 
     */  
    public static void main(String[] args) throws Exception{  
        boolean flag = true;  
        SSLContext context = null;  
        try {  
            KeyStore ks = KeyStore.getInstance("JKS");  
            ks.load(new FileInputStream(path), password);  
            KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");  
            kmf.init(ks, password);  
            KeyManager[] km = kmf.getKeyManagers();  
            context = SSLContext.getInstance("SSL");  
            context.init(km, null, null);  
        } catch (FileNotFoundException e) {  
            e.printStackTrace();  
        } catch (KeyStoreException e) {  
            e.printStackTrace();  
        } catch (IOException e) {  
            e.printStackTrace();  
        } catch (NoSuchAlgorithmException e) {  
            e.printStackTrace();  
        } catch (UnrecoverableKeyException e) {  
            e.printStackTrace();  
        } catch (KeyManagementException e) {  
            e.printStackTrace();  
        }  
        SSLServerSocketFactory ssf = (SSLServerSocketFactory) context.getServerSocketFactory();  
        try {  
            SSLServerSocket ss = (SSLServerSocket) ssf.createServerSocket(8000);  
            System.out.println("等待客户点连接。。。");  
            while (flag) {  
                Socket s = ss.accept();  
                System.out.println("接收到客户端连接");  
                DataInputStream dis=new DataInputStream(s.getInputStream());
                dis.readUTF();
                System.out.println("-----");
                ObjectOutputStream os = new ObjectOutputStream(s.getOutputStream());  
                os.writeObject("echo : Hello");  
                os.flush();  
                os.close();  
                System.out.println();  
                s.close();  
            }  
            ss.close();  
        } catch (IOException e) {  
            e.printStackTrace();  
        }  
    }  
}

客户端:

package client.cfca;

import java.io.DataOutputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.net.UnknownHostException;
import java.security.KeyStore;

import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocket;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.TrustManagerFactory;

/**
 * 
 * @author liuxin
 * @date   2018年6月24日
 */
public class TestSSLSocketClient {
	 private static String path = "E:/eclipse_work/tomcat-key/tomcat.keystore";  
	    private static char[] password = "tanglei".toCharArray();  
	  
	    /** 
	     * @param args 
	     */  
	    public static void main(String[] args) {  
	        SSLContext context = null;  
	        try {  
	            KeyStore ts = KeyStore.getInstance("JKS");  
	            ts.load(new FileInputStream(path), password);  
	            TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509");  
	            tmf.init(ts);  
	            TrustManager [] tm = tmf.getTrustManagers();  
	            context = SSLContext.getInstance("SSL");  
	            context.init(null, tm, null);  
	        } catch ( Exception e) {         //省略捕获的异常信息  
	            e.printStackTrace();  
	        }   
	        SSLSocketFactory ssf = context.getSocketFactory();  
	        try {  
	        	
	            SSLSocket ss = (SSLSocket) ssf.createSocket("127.0.0.1", 8000);  
	            System.out.println("客户端就绪。");  
	            DataOutputStream outputStream=new DataOutputStream(ss.getOutputStream());
//	            outputStream.write("ww".getBytes());
	            outputStream.writeUTF("22");
	            System.out.println("=======");
	            ObjectOutputStream os = new ObjectOutputStream(ss.getOutputStream());  
                os.writeObject("echo : Hello");  
//	            ObjectInputStream br = new ObjectInputStream(ss.getInputStream());  
	            System.out.println("客户端测试ok");  
	        } catch (UnknownHostException e) {  
	            e.printStackTrace();  
	        } catch (IOException e) {  
	            e.printStackTrace();  
	        }  
	    }  
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106086.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 常用降压电路设计「建议收藏」

    常用降压电路设计「建议收藏」一、5V转3.3V电路设计1.AMS1117-3V3AMS1117-xxx是一颗LDO芯片,这个系列有很多型号,后面的xxx代表输出电压,如果是AMS1117-ADJ表明输出是通过电阻调节的。实物图展示:常见封装:电路图:AMS1117-3.3最大输出可达1A,但是其压差较大,一般在1.1V左右,所以功耗和发热量也会随着电流的增大而急剧增大,对于大电流负载,不推荐使用LDO电路,使用DCDC电路效果更佳。2.ME6211C33ME6211C33是一颗低功耗低压差LDO芯片,其工作

    2022年6月20日
    32
  • Unified Functional Testing12.02(UFT)安装教程

    Unified Functional Testing12.02(UFT)安装教程UnifiedFunctionalTesting12.02安装教程相关说明​ UnifiedFunctionalTesting(UTF)是QuickTestProfessional(QTP)11.5版本以后的名称实验证明教程中的《安装UnifiedFunctionalTesting的Update》跳过也行,安装完MicrosoftScriptDebugger之后就可以…

    2022年5月8日
    181
  • C++使用eigen库做本征分解(eigendecomposition)

    C++使用eigen库做本征分解(eigendecomposition)Eigendecomposition的概念可见https://en.wikipedia.org/wiki/Eigendecomposition_of_a_matrix这里贴一段厄米矩阵的代码,见ht

    2022年8月2日
    4
  • phpstrom 2022激活码(JetBrains全家桶)

    (phpstrom 2022激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月31日
    313
  • android 应用的证书签名跟系统签名

    android 应用的证书签名跟系统签名作为软件行业的从业者都知道,一款软件的开发过程中肯定会诞生两种版本,即debug版本和release版本,debug版本包含有调试信息,一般来说都要比release版本大,android应用当然也不例外1.证书签名并不是所有的apk文件都能成功安装到安卓设备上,android系统要求只有签名后的apk文件才可以安装,因此我们还要对生成的apk文件进行签名才行在androidstudio中直接运行项目生成的都是测试版debug安装文…

    2022年6月9日
    50
  • 经典的SDR算法: 用半正定松弛法 ( Semidefinite Relaxation) 求解二次优化问题「建议收藏」

    经典的SDR算法: 用半正定松弛法 ( Semidefinite Relaxation) 求解二次优化问题「建议收藏」前言本文是博主对于Zhi-quanLuo老师的经典著作《SemidefiniteRelaxationofQuadraticOptimizationProblems》的读书笔记,希望可作为对全文以中文形式的核心梳理。单刀直入首先,SemidefiniteRelaxation(SDR)适用的问题可以写为如下形式:min⁡x∈Rn    xTCx s.t. xTAix⊵ibi,i=1,…,m(1)\begin{aligned}\min_{x\in

    2025年7月6日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号