获取服务端https证书 - Java版

简介:

接上篇,用java代码实现一下获取远程服务端证书,还是拿新浪首页测试,上代码:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package  org.test;
 
import  java.net.URL;
import  java.security.MessageDigest;
import  java.security.cert.Certificate;
import  java.security.cert.X509Certificate;
import  javax.net.ssl.HttpsURLConnection;
 
public  class  Application {
     public  static  void  main(String[] args)  throws  Exception {
         URL url =  new  URL( "https://www.sina.com.cn" );
         HttpsURLConnection conn = (HttpsURLConnection)url.openConnection();
         conn.connect();
         Certificate[] certs = conn.getServerCertificates();     //会拿到完整的证书链
         X509Certificate cert = (X509Certificate)certs[ 0 ];     //cert[0]是证书链的最下层
         System.out.println( "序号:"  + cert.getSerialNumber());
         System.out.println( "颁发给:"  + cert.getSubjectDN().getName());
         System.out.println( "颁发者:"  + cert.getIssuerDN().getName());
         System.out.println( "起始:"  + cert.getNotBefore());
         System.out.println( "过期:"  + cert.getNotAfter());
         System.out.println( "算法:"  + cert.getSigAlgName());
         System.out.println( "指纹:"  + getThumbPrint(cert));
         conn.disconnect();
     }
 
     private  static  String getThumbPrint(X509Certificate cert)  throws  Exception {
         MessageDigest md = MessageDigest.getInstance( "SHA-1" );
         byte [] der = cert.getEncoded();
         md.update(der);
         byte [] digest = md.digest();
         return  bytesToHexString(digest);
     }
     
     private  static  String bytesToHexString( byte [] src) {
         StringBuilder stringBuilder =  new  StringBuilder( "" );
         if  (src ==  null  || src.length <=  0 ) {
             return  null ;
         }
         for  ( int  i =  0 ; i < src.length; i++) {
             int  v = src[i] &  0xFF ;
             String hv = Integer.toHexString(v);
             if  (hv.length() <  2 ) {
                 stringBuilder.append( 0 );
             }
             stringBuilder.append(hv);
         }
         return  stringBuilder.toString();
     }
}


运行看效果,得到的输出:

序号:78653003708979598891221754220386804014

颁发给:CN=sina.com, OU="Sina.com Technology(China)Co.,ltd", O="Sina.com Technology(China)Co.,ltd", L=Beijing, ST=Beijing, C=CN

颁发者:CN=GeoTrust SSL CA - G3, O=GeoTrust Inc., C=US

起始:Tue Feb 21 08:00:00 CST 2017

过期:Tue Nov 26 07:59:59 CST 2019

算法:SHA256withRSA

指纹:6ce7b869e4d6f77a31a967af2dc1b904fd059aa3


与之前是一样的。



     本文转自 BoyTNT 51CTO博客,原文链接:http://blog.51cto.com/boytnt/2052616,如需转载请自行联系原作者




相关文章
|
16小时前
|
Web App开发 缓存 前端开发
《手把手教你》系列技巧篇(四十四)-java+ selenium自动化测试-处理https 安全问题或者非信任站点-下篇(详解教程)
【5月更文挑战第8天】这篇文档介绍了如何在IE、Chrome和Firefox浏览器中处理不信任证书的问题。作者北京-宏哥分享了如何通过编程方式跳过浏览器的证书警告,直接访问不受信任的HTTPS网站。文章分为几个部分,首先简要介绍了问题背景,然后详细讲解了在Chrome浏览器中的两种方法,包括代码设计和运行效果,并给出了其他浏览器的相关信息和参考资料。最后,作者总结了处理此类问题的一些通用技巧。
16 2
|
16小时前
|
Web App开发 JavaScript 前端开发
《手把手教你》系列技巧篇(四十三)-java+ selenium自动化测试-处理https 安全问题或者非信任站点-上篇(详解教程)
【5月更文挑战第7天】本文介绍了如何在Java+Selenium自动化测试中处理浏览器对不信任证书的处理方法,特别是针对IE、Chrome和Firefox浏览器。在某些情况下,访问HTTPS网站时会遇到证书不可信的警告,但可以通过编程方式跳过这些警告。
13 1
|
16小时前
|
域名解析 网络协议 应用服务中间件
阿里云SSL证书配置(HTTPS证书配置)
该内容是一个关于如何在阿里云上准备和购买SSL证书,以及如何为网站启用HTTPS的步骤指南。首先,需要注册并实名认证阿里云账号,然后在SSL证书控制台选择证书类型、品牌和时长进行购买。申请证书时填写域名信息,并进行DNS验证,这包括在阿里云域名管理板块添加解析记录。完成验证后提交审核,等待证书审核通过并下载Nginx格式的证书文件。最后,将证书配置到网站服务器以启用HTTPS。整个过程涉及账户注册、实名认证、证书购买、DNS设置和证书下载及安装。
168 0
|
16小时前
|
网络安全 数据安全/隐私保护 Docker
免费的HTTPS证书
免费的HTTPS证书
97 1
|
16小时前
|
安全 搜索推荐 网络安全
【HTTPS】https证书详细解释
文章简单的讲解了一下https是什么,以及是干什么用的
127 0
【HTTPS】https证书详细解释
|
16小时前
|
存储 网络安全 数据安全/隐私保护
Windows Server 2019 IIS HTTPS证书部署流程详解
Windows Server 2019 IIS HTTPS证书部署流程详解
|
16小时前
|
安全 网络安全 CDN
阿里云CDN HTTPS 证书配置流程
阿里云CDN HTTPS 证书配置流程
220 1
|
17小时前
|
存储 前端开发 Java
JSP(全称:Java Server Pages):Java 服务端页面
JSP(全称:Java Server Pages):Java 服务端页面
74 0
|
17小时前
|
安全 算法 网络安全
CDN:配置HTTPS证书
CDN:配置HTTPS证书
62 1
|
17小时前
|
JSON 安全 网络安全
超详细的用户认证、权限、安全原理详解(认证、权限、JWT、RFC 7235、HTTPS、HSTS、PC端、服务端、移动端、第三方认证等等)
超详细的用户认证、权限、安全原理详解(认证、权限、JWT、RFC 7235、HTTPS、HSTS、PC端、服务端、移动端、第三方认证等等)
373 0