CloseableHttpClient加载证书来访问https网站

对安全性有要求的网站一般使用https来加密传输的请求和响应。https离不开证书,关于证书不在多说。Apache的HttpClient支持https,

下面是官方的样例程序,程序中使用了my.store这个文件,

这个文件不是网站的证书,而是一份包含自己密码的自己的证书库。这个文件是需要自己生成的,使用jdk中的keytool命令可以很方便的生成my.store文件。步骤如下(以支付宝为例):

  1. 浏览器(以chrome为例)访问https://www.alipay.com/,点击域名左侧的小锁,可以查看支付宝的证书信息


  2. 将支付包的证书信息导出,证书格式有很多中,der、cer等。随便选择即可。

  3. 命令行或者shell执行 keytool     -import -alias "my alipay cert" -file www.alipay.com.cert     -keystore my.store,

如果keytool命令不识别,去检查一下jdk的环境变量是否设置正确。”my alipay cert”是个别名,随便取。“www.alipay.com.cert”这个文件就是从浏览器中导出的支付宝的证书。

“my.store”是生成的自己 的证书库文件。回车执行,效果如下:

OK,现在可以执行下面的代码了:

[java]  view plain  copy
  1. package com.yeetrack.httpclient;  
  2.   
  3.    /** 
  4.  
  5.    * Created with IntelliJ IDEA. 
  6.  
  7.    * User: victor 
  8.  
  9.    * Date: 13-10-11 
  10.  
  11.    * Time: 下午3:09 
  12.  
  13.    * To change this template use File | Settings | File Templates. 
  14.  
  15.    */  
  16.   
  17.    import java.io.File;  
  18.   
  19.    import java.io.FileInputStream;  
  20.   
  21.    import java.security.KeyStore;  
  22.   
  23.    import javax.net.ssl.SSLContext;  
  24.   
  25.    import org.apache.http.HttpEntity;  
  26.   
  27.    import org.apache.http.client.methods.CloseableHttpResponse;  
  28.   
  29.    import org.apache.http.client.methods.HttpGet;  
  30.   
  31.    import org.apache.http.conn.ssl.SSLContexts;  
  32.   
  33.    import org.apache.http.conn.ssl.SSLConnectionSocketFactory;  
  34.   
  35.    import org.apache.http.impl.client.CloseableHttpClient;  
  36.   
  37.    import org.apache.http.impl.client.HttpClients;  
  38.   
  39.    import org.apache.http.util.EntityUtils;  
  40.   
  41.   
  42.   
  43.    /** 
  44.  
  45.    * 代码展示了如果使用ssl context创建安全socket连接 
  46.  
  47.    */  
  48.   
  49.    public class ClientCustomSSL {  
  50.   
  51.        public final static void main(String[] args) throws Exception {  
  52.   
  53.            KeyStore trustStore  = KeyStore.getInstance(KeyStore.getDefaultType());  
  54.   
  55.            //加载证书文件  
  56.   
  57.            FileInputStream instream = new FileInputStream(new File("/home/victor/my.store"));  
  58.   
  59.            try {  
  60.   
  61.                trustStore.load(instream, "mypassword".toCharArray());  
  62.   
  63.            } finally {  
  64.   
  65.                instream.close();  
  66.   
  67.            }  
  68.   
  69.            SSLContext sslcontext = SSLContexts.custom().loadTrustMaterial(trustStore).build();  
  70.   
  71.            SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(sslcontext,  
  72.   
  73.                    SSLConnectionSocketFactory.BROWSER_COMPATIBLE_HOSTNAME_VERIFIER);  
  74.   
  75.            CloseableHttpClient httpclient = HttpClients.custom()  
  76.   
  77.                    .setSSLSocketFactory(sslsf)  
  78.   
  79.                    .build();  
  80.   
  81.            try  
  82.   
  83.            {  
  84.   
  85.                //访问支付宝  
  86.   
  87.                HttpGet httpget = new HttpGet("https://www.alipay.com/");  
  88.   
  89.                System.out.println("executing request" + httpget.getRequestLine());  
  90.   
  91.                CloseableHttpResponse response = httpclient.execute(httpget);  
  92.   
  93.                try {  
  94.   
  95.                    HttpEntity entity = response.getEntity();  
  96.   
  97.                    System.out.println("----------------------------------------");  
  98.   
  99.                    System.out.println(response.getStatusLine());  
  100.   
  101.                    if (entity != null) {  
  102.   
  103.                        System.out.println(EntityUtils.toString(entity));  
  104.   
  105.                    }  
  106.   
  107.                } finally {  
  108.   
  109.                    response.close();  
  110.   
  111.                }  
  112.   
  113.            } finally {  
  114.   
  115.                httpclient.close();  
  116.   
  117.            }  
  118.   
  119.        }  
  120.   
  121.    }   
### 回答1: 要使用Java实现读取证书访问HTTPS接口,需要遵循以下步骤: 1. 获取证书:首先,需要获取要访问HTTPS服务器的证书。可以使用浏览器访问该服务器,并导出证书为一个文件(一般为.crt或.pem格式)。 2. 将证书导入Java密钥库:将第一步获得的证书导入Java密钥库中。可以使用Java提供的keytool工具,执行类似以下命令: ``` keytool -import -file /path/to/certificate.crt -alias servercert -keystore /path/to/keystore.jks ``` 这将把证书导入到指定的密钥库中,并为证书指定一个别名。 3. 创建SSLContext:使用Java的KeyStore类加载密钥库,并创建一个包含需要的信任管理器的SSLContext实例。可以使用以下代码实现: ```java KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType()); FileInputStream trustStoreFile = new FileInputStream("/path/to/keystore.jks"); trustStore.load(trustStoreFile, "keystorepassword".toCharArray()); TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); trustManagerFactory.init(trustStore); SSLContext sslContext = SSLContext.getInstance("TLS"); sslContext.init(null, trustManagerFactory.getTrustManagers(), null); ``` 4. 创建HttpClient:使用Apache HttpClient库创建一个HttpClient对象,并指定使用刚才创建的SSLContext实例来进行HTTPS连接。可以使用以下代码实现: ```java HttpClient client = HttpClients.custom().setSSLContext(sslContext).build(); ``` 5. 发送HTTPS请求:使用HttpClient对象发送HTTPS请求到目标接口。可以使用HttpGet或HttpPost等请求类型,并执行execute方法,如下所示: ```java HttpGet request = new HttpGet("https://api.example.com"); HttpResponse response = client.execute(request); ``` 以上步骤完成后,即可通过Java程序读取证书访问HTTPS接口。需要注意的是,从第3步开始的代码需要进行异常处理,同时确保路径和密码等参数正确配置。 ### 回答2: 要用Java实现读取证书访问HTTPS接口,可以按照以下步骤进行操作: 1. 确保你已经获取到了HTTPS接口所需的证书文件,一般为以.crt、.pem或.jks为扩展名的文件。 2. 首先,需要创建一个HttpClient对象,用于发送HTTP请求。可以使用Apache HttpClient库来实现,该库提供了丰富的HTTP客户端功能。 3. 创建SSLContext对象,用于在发送HTTPS请求时验证服务器证书的有效性。可以使用KeyStore类加载证书文件,并通过TrustManagerFactory初始化SSLContext。 4. 创建一个HostnameVerifier对象,用于验证服务器主机名的有效性。可以使用自定义的实现类,也可以使用默认的实现类。 5. 创建一个HttpClientBuilder对象,并将SSLContext和HostnameVerifier对象设置给它。 6. 使用HttpClientBuilder对象创建HttpClient对象,同时设置代理、超时等相关参数。 7. 创建一个HttpGet或HttpPost对象,设置请求的URL和相关参数。 8. 调用HttpClient对象的execute方法发送请求,并获取返回的HttpResponse对象。 9. 从HttpResponse对象中获取服务器返回的数据,并进行后续处理。 示例代码如下: ```java import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.security.KeyStore; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManagerFactory; import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpGet; import org.apache.http.conn.ssl.SSLConnectionSocketFactory; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.ssl.SSLContextBuilder; import org.apache.http.ssl.TrustManagerFactoryBuilder; public class HttpsClientExample { public static void main(String[] args) { try { // 加载证书 KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType()); trustStore.load(HttpsClientExample.class.getResourceAsStream("client-truststore.crt"), "password".toCharArray()); TrustManagerFactory trustManagerFactory = TrustManagerFactoryBuilder.newBuilder() .withDefaultAlgorithm() .withKeystore(trustStore) .build(); SSLContext sslContext = SSLContextBuilder.create() .loadTrustMaterial(trustManagerFactory) .build(); CloseableHttpClient httpClient = HttpClients.custom() .setSSLSocketFactory(new SSLConnectionSocketFactory(sslContext)) .build(); HttpGet httpGet = new HttpGet("https://example.com/api"); HttpResponse response = httpClient.execute(httpGet); HttpEntity entity = response.getEntity(); // 读取返回的数据 InputStream inputStream = entity.getContent(); BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream)); String line; while ((line = reader.readLine()) != null) { System.out.println(line); } httpClient.close(); } catch (Exception e) { e.printStackTrace(); } } } ``` 以上就是使用Java实现读取证书访问HTTPS接口的基本步骤,根据具体的证书和接口要求,可能需要进行一些额外的配置和参数设置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值