Java加载证书,访问12306的https链接

下载12306的证书,访问12306网站,下载12306的证书

1111.jpg

导出证书

2222.jpg

3333.jpg

导出完成后,导入证书

4444.jpg

查看是否导入

5555.jpg

java中加载证书

public static void main( String[] args ){
PrintWriter out = null;
   BufferedReader in = null;
   String result = "";
   //设置证书
   System.setProperty("javax.net.ssl.trustStore","D:\\Program Files\\Java\\jdk1.7.0_79\\bin\\12306d.keystore");  
   System.setProperty("javax.net.ssl.trustStorePassword", "12306java");  
   try {
       URL realUrl = new URL("https://kyfw.12306.cn/otn/login/loginAysnSuggest");
       // 打开和URL之间的连接
       URLConnection conn = realUrl.openConnection();
       // 设置通用的请求属性
       conn.setRequestProperty("accept", "*/*");
       conn.setRequestProperty("connection", "Keep-Alive");
       conn.setRequestProperty("user-agent",
               "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
       // 发送POST请求必须设置如下两行
       conn.setDoOutput(true);
       conn.setDoInput(true);
       // 获取URLConnection对象对应的输出流
       out = new PrintWriter(conn.getOutputStream());
       // 发送请求参数
       out.print("loginUserDTO.user_name=aaa&userDTO.password=123456&randCode=182,51,19,130");
       // flush输出流的缓冲
       out.flush();
       // 定义BufferedReader输入流来读取URL的响应
       in = new BufferedReader(
               new InputStreamReader(conn.getInputStream()));
       String line;
       while ((line = in.readLine()) != null) {
           result += line;
       }
       System.out.println(result);
   } catch (Exception e) {
       System.out.println("发送 POST 请求出现异常!"+e);
       e.printStackTrace();
   }
   //使用finally块来关闭输出流、输入流
   finally{
       try{
           if(out!=null){
               out.close();
           }
           if(in!=null){
               in.close();
           }
       }
       catch(IOException ex){
           ex.printStackTrace();
       }
   }
}

本文由微儿博客原创,博客地址:www.weare.net.cn 或者点击 微儿博客

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用JavaHttpsURLConnection类来发出自定义证书路径的HTTPS请求。以下是一个示例代码: ```java import java.io.BufferedReader; import java.io.InputStreamReader; import java.net.URL; import javax.net.ssl.HttpsURLConnection; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManagerFactory; import java.io.FileInputStream; import java.security.KeyStore; public class CustomCertHttpsRequest { public static void main(String[] args) throws Exception { // 证书路径 String certPath = "/path/to/certificate.pem"; // 证书密码 String certPassword = "password"; // 请求URL String url = "https://example.com"; // 加载证书 KeyStore keyStore = KeyStore.getInstance("JKS"); FileInputStream fis = new FileInputStream(certPath); keyStore.load(fis, certPassword.toCharArray()); // 创建TrustManagerFactory TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); tmf.init(keyStore); // 创建SSLContext SSLContext sslContext = SSLContext.getInstance("TLS"); sslContext.init(null, tmf.getTrustManagers(), null); // 创建HttpsURLConnection URL requestUrl = new URL(url); HttpsURLConnection conn = (HttpsURLConnection) requestUrl.openConnection(); conn.setSSLSocketFactory(sslContext.getSocketFactory()); // 发送HTTPS请求 BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream())); String inputLine; while ((inputLine = in.readLine()) != null) { System.out.println(inputLine); } in.close(); } } ``` 在上面的代码中,我们首先定义证书路径和密码。然后,我们加载证书文件,并使用TrustManagerFactory和SSLContext创建一个安全连接。最后,我们创建HttpsURLConnection,将证书套接字工厂设置为SSLContext的套接字工厂,并使用openConnection()方法发送HTTPS请求。 请注意,如果您使用的是自签名证书,则需要在加载证书之前禁用主机名验证。例如: ```java HttpsURLConnection.setDefaultHostnameVerifier((hostname, sslSession) -> true); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值