httpClient强制指定TLS1.1协议访问HTTPS

自用备份~~
public static String httpsByTls(String url,Map params) throws Exception{
    // 实现一个X509TrustManager接口,用于绕过验证,不用修改里面的方法
    X509TrustManager trustManager = new X509TrustManager() {
        @Override
        public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
        }

        @Override
        public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
        }

        @Override
        public X509Certificate[] getAcceptedIssuers() {
            return null;
        }

    };

    SSLContext sc = SSLContext.getInstance("TLSv1.1");
    sc.init(null, new TrustManager[] { trustManager }, null);

    SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(sc);
    CloseableHttpClient httpclient = HttpClients.custom().setSSLSocketFactory(sslsf).build();
    HttpPost post = new HttpPost(url);
    post.addHeader("Content-Type","application/x-www-form-urlencoded; charset=UTF-8");
    post.getParams().setParameter(HttpMethodParams.HTTP_CONTENT_CHARSET,
            "UTF-8");
    List nameValuePairs = new ArrayList();
    Set set = params.keySet();
    for (Object str : set) {
        nameValuePairs.add(new BasicNameValuePair(str.toString(), params.get(str)));
    }
    post.setEntity(new UrlEncodedFormEntity(nameValuePairs, "UTF-8"));

    CloseableHttpResponse response = httpclient.execute(post);
    String returnStr="";
    try {
        HttpEntity entity = response.getEntity();
        returnStr= EntityUtils.toString(entity);
    } finally {
        response.close();
    }
    return returnStr;
}
public static void main(String[] args) throws Exception {
    String url = "https://192.168.2.176:8080/ytsafe/tourist/queryPunishByYT.shtml";
    Map params = new HashMap<>();
    params.put("year","2019");
    params.put("month","01");
    String returnStr=httpsByTls(url,params);
    System.out.println("returnStr的值是:---"+ returnStr + ",当前方法=HttpsUtil.main()");
}

你可能感兴趣的:(HttpClient)