好久没用过SSL认证了,东西久不用,就有点生疏。博客就是有这个好处,可以做备忘录。
java中是通过SSL认证,使用的是SSLSocket,通过SSLSocketFactory可以获得SSLSocket实例对象。通常SSLSocketFactory需要一个SSLContext环境对象来构建,
构建一个SSLContext 环境:
SSLContext sslc=SSLContext.getInstance("SSLv3");
 // 构造SSL环境,指定SSL版本为3.0,也可以使用TLSv1,但是SSLv3更加常用。
sslc.init(KeyManager[],TrustManager[]null);
//KeyManager[] 第一个参数是授权的密钥管理器,用来授权验证。TrustManager[]第二个是被授权的证书管理器,用来验证服务器端的证书。第三个参数是一个随机数值,可以填写null。如果只是服务器传输数据给客户端来验证,就传入第一个参数就可以,客户端构建环境就传入第二个参数。
双向认证的话,就同时使用两个管理器。
服务端:

[代码]java代码:

[js] view plaincopyprint?
  1. import java.io.FileInputStream;
  2. import java.io.*;
  3. import java.net.Socket;
  4. import java.security.KeyStore;
  5. import javax.net.ssl.KeyManagerFactory;
  6. import javax.net.ssl.SSLContext;
  7. import javax.net.ssl.SSLServerSocket;
  8. import javax.net.ssl.SSLServerSocketFactory;
  9. public class KeystoreTest {
  10. /**
  11. * name:KeystoreTest
  12. * author:suju
  13. */
  14. public static void main(String[] args) throws Exception{
  15. String key="c:/.keystore";
  16. KeyStore keystore=KeyStore.getInstance("JKS");
  17. //keystore的类型,默认是jks
  18. keystore.load(new FileInputStream(key),"123456".toCharArray());
  19. //创建jkd密钥访问库    123456是keystore密码。
  20. KeyManagerFactory kmf=KeyManagerFactory.getInstance("SunX509");
  21. kmf.init(keystore,"asdfgh".toCharArray());
  22. //asdfgh是key密码。
  23. //创建管理jks密钥库的x509密钥管理器,用来管理密钥,需要key的密码
  24. SSLContext sslc=SSLContext.getInstance("SSLv3");
  25. // 构造SSL环境,指定SSL版本为3.0,也可以使用TLSv1,但是SSLv3更加常用。
  26. sslc.init(kmf.getKeyManagers(),null,null);
  27. //第二个参数TrustManager[] 是认证管理器,在需要双向认证时使用,
  28. //构造ssl环境
  29. SSLServerSocketFactory sslfactory=sslc.getServerSocketFactory();
  30. SSLServerSocket serversocket=(SSLServerSocket) sslfactory.createServerSocket(9999);
  31. //创建serversocket,监听,并传输数据来验证授权
  32. for(int i=0;i<15;i++)
  33. {
  34. final Socket socket=serversocket.accept();
  35. new Thread(){
  36. public void run()
  37. {
  38. try{
  39. InputStream is=socket.getInputStream();
  40. OutputStream os=socket.getOutputStream();
  41. byte[] buf=new byte[1024];
  42. int len=is.read(buf);
  43. System.out.println(new String(buf));
  44. os.write("ssl test".getBytes());
  45. os.close();
  46. is.close();
  47. }catch(Exception e)
  48. {// }
  49. }
  50. }.start();
  51. }
  52. serversocket.close();
  53. }
  54. }

import java.io.FileInputStream;
import java.io.*;
import java.net.Socket;
import java.security.KeyStore;import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLServerSocket;
import javax.net.ssl.SSLServerSocketFactory;public class KeystoreTest {/*** name:KeystoreTest* author:suju*/public static void main(String[] args) throws Exception{String key="c:/.keystore";KeyStore keystore=KeyStore.getInstance("JKS");//keystore的类型,默认是jkskeystore.load(new FileInputStream(key),"123456".toCharArray());//创建jkd密钥访问库  123456是keystore密码。KeyManagerFactory kmf=KeyManagerFactory.getInstance("SunX509");kmf.init(keystore,"asdfgh".toCharArray());//asdfgh是key密码。//创建管理jks密钥库的x509密钥管理器,用来管理密钥,需要key的密码SSLContext sslc=SSLContext.getInstance("SSLv3");// 构造SSL环境,指定SSL版本为3.0,也可以使用TLSv1,但是SSLv3更加常用。sslc.init(kmf.getKeyManagers(),null,null);//第二个参数TrustManager[] 是认证管理器,在需要双向认证时使用,//构造ssl环境SSLServerSocketFactory sslfactory=sslc.getServerSocketFactory();SSLServerSocket serversocket=(SSLServerSocket) sslfactory.createServerSocket(9999);//创建serversocket,监听,并传输数据来验证授权for(int i=0;i<15;i++){ final Socket socket=serversocket.accept();new Thread(){public void run(){try{InputStream is=socket.getInputStream();OutputStream os=socket.getOutputStream();byte[] buf=new byte[1024];int len=is.read(buf);System.out.println(new String(buf));os.write("ssl test".getBytes());os.close();is.close();}catch(Exception e){// }}}.start();}serversocket.close();  }
}

客户端:

[代码]java代码:

[js] view plaincopyprint?
  1. import java.io.FileInputStream;
  2. import java.io.InputStream;
  3. import java.io.OutputStream;
  4. import java.security.KeyStore;
  5. import javax.net.ssl.KeyManagerFactory;
  6. import javax.net.ssl.SSLContext;
  7. import javax.net.ssl.SSLServerSocket;
  8. import javax.net.ssl.SSLServerSocketFactory;
  9. import javax.net.ssl.SSLSocket;
  10. import javax.net.ssl.SSLSocketFactory;
  11. import javax.net.ssl.TrustManagerFactory;
  12. public class KeystoreTestClient {
  13. /**
  14. * name:KeystoreTestClient
  15. * author:suju
  16. */
  17. public static void main(String[] args) throws Exception{
  18. String key="c:/client";
  19. KeyStore keystore=KeyStore.getInstance("JKS");  //创建一个keystore来管理密钥库
  20. keystore.load(new FileInputStream(key),"123456".toCharArray());
  21. //创建jkd密钥访问库
  22. TrustManagerFactory tmf=TrustManagerFactory.getInstance("SunX509");
  23. tmf.init(keystore);                 //验证数据,可以不传入key密码
  24. //创建TrustManagerFactory,管理授权证书
  25. SSLContext sslc=SSLContext.getInstance("SSLv3");
  26. // 构造SSL环境,指定SSL版本为3.0,也可以使用TLSv1,但是SSLv3更加常用。
  27. sslc.init(null,tmf.getTrustManagers(),null);
  28. //KeyManager[] 第一个参数是授权的密钥管理器,用来授权验证。第二个是被授权的证书管理器,
  29. //用来验证服务器端的证书。只验证服务器数据,第一个管理器可以为null
  30. //构造ssl环境
  31. SSLSocketFactory sslfactory=sslc.getSocketFactory();
  32. SSLSocket socket=(SSLSocket) sslfactory.createSocket("127.0.0.1",9999);
  33. //创建serversocket通过传输数据来验证授权
  34. InputStream is=socket.getInputStream();
  35. OutputStream os=socket.getOutputStream();
  36. os.write("client".getBytes());
  37. byte[] buf=new byte[1024];
  38. int len=is.read(buf);
  39. System.out.println(new String(buf));
  40. os.close();
  41. is.close();
  42. }
  43. }

import java.io.FileInputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.security.KeyStore;import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLServerSocket;
import javax.net.ssl.SSLServerSocketFactory;
import javax.net.ssl.SSLSocket;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManagerFactory;public class KeystoreTestClient {/*** name:KeystoreTestClient* author:suju*/public static void main(String[] args) throws Exception{String key="c:/client";KeyStore keystore=KeyStore.getInstance("JKS");    //创建一个keystore来管理密钥库keystore.load(new FileInputStream(key),"123456".toCharArray());//创建jkd密钥访问库TrustManagerFactory tmf=TrustManagerFactory.getInstance("SunX509");tmf.init(keystore);                  //验证数据,可以不传入key密码//创建TrustManagerFactory,管理授权证书SSLContext sslc=SSLContext.getInstance("SSLv3");// 构造SSL环境,指定SSL版本为3.0,也可以使用TLSv1,但是SSLv3更加常用。sslc.init(null,tmf.getTrustManagers(),null);//KeyManager[] 第一个参数是授权的密钥管理器,用来授权验证。第二个是被授权的证书管理器,//用来验证服务器端的证书。只验证服务器数据,第一个管理器可以为null//构造ssl环境SSLSocketFactory sslfactory=sslc.getSocketFactory();SSLSocket socket=(SSLSocket) sslfactory.createSocket("127.0.0.1",9999);//创建serversocket通过传输数据来验证授权InputStream is=socket.getInputStream();OutputStream os=socket.getOutputStream();        os.write("client".getBytes());        byte[] buf=new byte[1024];int len=is.read(buf);System.out.println(new String(buf)); os.close();is.close();}
}
使用java中自带keytool管理keystore。
**经常忘记参数,写下来记住。
默认密钥库下创建一个key     keytool -genkeypair

显示默认keystore的key详细信息  keytool -list -v

使用其他keystore来创建key,如果keystore不存在就创建一个新的。 keytool --genkeypair -keystore c:\client

导出一个key    keytool -exportcert -alias mykey -file c:\mykey.cer

导入一个key到一个keystore,  keytool -importcert -alias mykey -file c:\mykey.cer -keystore c:\client

还有很多关于key的操作,keytool提供了-help帮助命令

原文地址:http://blog.csdn.net/a495614205/article/details/12648939

java中 SSL认证和keystore使用相关推荐

  1. java ssl是什么意思_java中SSL是什么?包括哪些内容?

    大家都知道,java中关于网络安全的知识是非常多的,这也是java在日常的学习中比较重要的一个点.java中SSL的定义也是需要掌握的,一起来了解一下吧. 首先,SSL代表安全套接字层. 它是一种用于 ...

  2. 【ssl认证、证书】java中的ssl语法API说明(SSLContext)、与keytool 工具的联系

    文章目录 1. 前言 java中的ssl语法与keytool 工具的联系 2. SSLContext的体系 2.1 KeyStore 2.1.1 通过证书库文件创建: 2.1.2 随机生成自签名证书库 ...

  3. Java笔记-基于Spring Boot的SOAP双向SSL认证及WS-Security

    这里服务端开放了简单的SOAP的API,但是想获取数据时需要双向SSL以及WS-Security签名. 其中对应的xsd文件如下: <xs:schema xmlns:xs="http: ...

  4. 【ssl认证、证书】SSL双向认证java实战、keytool创建证书

    文章目录 概述 keytool示例 参考 相关文章: //-----------Java SSL begin---------------------- [ssl认证.证书]SSL双向认证和SSL单向 ...

  5. JAVA爬虫https_java爬虫问题一:解决使用htmlunit 时候ssl认证失败问题

    java爬虫问题一:解决使用htmlunit 时候ssl认证失败问题 凯哥Java 凯哥java 前言: 在使用htmlunit 爬取其他网站信息的时候,提示错误信息:unable to find v ...

  6. HTTPS 中双向认证SSL 协议的具体过程

    HTTPS 中双向认证SSL 协议的具体过程: 这里总结为详细的步骤: ① 浏览器发送一个连接请求给安全服务器. ② 服务器将自己的证书,以及同证书相关的信息发送给客户浏览器. ③ 客户浏览器检查服务 ...

  7. 华为hcie认证中SSL基本介绍华为hcie必看

    华为hcie认证中SSL基本介绍华为hcie必看,SSL 全称为Secure Sockets Layer,安全套接层.是一种提供保证私密性的安全协议.SSL能使客户端与服务器之间的通信不被截取及窃听, ...

  8. java中setconstrations_java程序员认证模拟试题及解析

    java程序员认证模拟试题及解析 天将降大任于是人也,必先苦其心志,劳其筋骨,饿其体肤,空乏其身,行拂乱其所为.以下是小编为大家搜索整理的java程序员认证模拟试题及解析,希望能给大家带来帮助!更多精 ...

  9. 解决Java中JWT的token认证接口测试时:认证失败,无法访问系统资

    步骤: 登录页面后,右击检查->network->XHR->复制Authorization的内容 粘贴到postman中安全认证哪里,类型下载token.

最新文章

  1. 【实战】OpenCV钢管计数分析与方法比较
  2. 海思3559与全志a83t比较
  3. linux命令行怎么注释,Bash Shell 注释多行的几种方法
  4. 深度学习100例-卷积神经网络(LeNet-5)深度学习里的“Hello Word” | 第22天
  5. LinearLayout和RelativeLayoutnbs…
  6. leetcode-有效的括号(三种语言不同思路)
  7. HDU - 5008 Boring String Problem(后缀数组+二分)
  8. 这个偏僻的小山村竟出了12位博士28位硕士,高产“学霸”背后原因曝光......
  9. linux-bash的基本-自动补全-快捷键-历史-命令的别名
  10. UpdateProgress控件
  11. 【英语学习】【WOTD】tenacious 释义/词源/示例
  12. centos php 开启mysql扩展_CentOS 7下部署php7.1和开启MySQL扩展的方法教程
  13. Java用POI导出Excel表格中的数据
  14. linux syn_recv过多ip,SYN_RECV处理方案
  15. Incorrect string value: '\xF0\x9F\x91\x93\xF0\x9F...' for column 'xxx' at row 1
  16. 【金融项目】尚融宝项目(十六)
  17. matlab 数值计算课 二阶微分方程-龙格库塔方法 ODE45
  18. 数据结构-青蛙杯棒球比赛
  19. 携职教育:2022年初级会计考试证书领取流程及所需材料
  20. Ubuntu通过samba winbind集成AD账号

热门文章

  1. Cast from pointer to smaller type 'int' loses information”
  2. Coursera 学习记录:Tomorrow never knows?(实现日期加一的操作)
  3. 51单片机实现两路AD检测、数码管显示、串口获取
  4. Mac和Windows键盘对应关系
  5. 我国拟立法禁止大数据杀熟;工信部通报43款App违规整改不彻底丨钛晚报
  6. 靶场发展态势③美国防部赛博安全靶场(IAR/CSR)
  7. 如何携号转网只需三步
  8. 【2022-9-21最新】青龙面板搭建+sillyGirl+对接微信公众号+onebot
  9. gif动图过大怎么处理?怎么压缩gif图片大小?
  10. 网站运营中长尾关键词优化策略