導航
java開發中需要調用其他服務的對外提供的https請求,上一篇寫的是調用http,處理方式不太一樣,可以參考如下代碼:
注:調用的主類比較簡單就不寫了。
pom.xml
<dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpcore</artifactId> <version>4.4.10</version> </dependency> <dependency> <groupId>commons-httpclient</groupId> <artifactId>commons-httpclient</artifactId> <version>3.1</version> </dependency> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient</artifactId> <version>4.5.6</version> </dependency>
HttpsUtil.class類
package cn.cas.xjipc.yjsapplication.unit; import org.apache.commons.httpclient.util.HttpURLConnection; import org.springframework.stereotype.Component; import java.io.*; import java.net.URL; import java.security.KeyManagementException; import java.security.NoSuchAlgorithmException; import java.security.cert.CertificateException; import java.security.cert.X509Certificate; import javax.net.ssl.*; @Component public class HttpsUtil { private static class TrustAnyTrustManager implements X509TrustManager { public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException { } public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException { } public X509Certificate[] getAcceptedIssuers() { return new X509Certificate[]{}; } } private static class TrustAnyHostnameVerifier implements HostnameVerifier { public boolean verify(String hostname, SSLSession session) { return true; } } /** * post方式請求服務器(https協議) * * @param url 請求地址 * @param content 參數 * @param charset 編碼 * @return * @throws NoSuchAlgorithmException * @throws KeyManagementException * @throws IOException */ public String post(String url, String content, String charset) throws NoSuchAlgorithmException, KeyManagementException, IOException { String result = ""; SSLContext sc = SSLContext.getInstance("SSL"); sc.init(null, new TrustManager[]{new TrustAnyTrustManager()}, new java.security.SecureRandom()); URL console = new URL(url); HttpsURLConnection conn = (HttpsURLConnection) console.openConnection(); conn.setRequestProperty("Content-Type", "application/json; charset=utf-8"); conn.setSSLSocketFactory(sc.getSocketFactory()); conn.setHostnameVerifier(new TrustAnyHostnameVerifier()); conn.setDoOutput(true); conn.connect(); DataOutputStream out = new DataOutputStream(conn.getOutputStream()); out.write(content.getBytes(charset)); // 刷新、關閉 out.flush(); out.close(); InputStream is = conn.getInputStream(); if (is != null) { ByteArrayOutputStream outStream = new ByteArrayOutputStream(); byte[] buffer = new byte[1024]; int len = 0; while ((len = is.read(buffer)) != -1) { outStream.write(buffer, 0, len); } is.close(); byte[] array = outStream.toByteArray(); result = new String(array, "utf-8"); return result; } return null; } /** * put方式請求服務器(https協議) * * @param url 請求地址 * @param content 參數 * @param token 編碼 * @return * @throws NoSuchAlgorithmException * @throws KeyManagementException * @throws IOException */ public String put(String url, String content, String token) throws NoSuchAlgorithmException, KeyManagementException, IOException { String result = ""; SSLContext sc = SSLContext.getInstance("SSL"); sc.init(null, new TrustManager[]{new TrustAnyTrustManager()}, new java.security.SecureRandom()); URL console = new URL(url); HttpsURLConnection conn = (HttpsURLConnection) console.openConnection(); conn.setRequestMethod("PUT"); conn.setSSLSocketFactory(sc.getSocketFactory()); conn.setHostnameVerifier(new TrustAnyHostnameVerifier()); conn.setDoOutput(true); conn.setRequestProperty("Content-Type", "application/json; charset=utf-8"); //conn.setRequestProperty("Authorization", "xxxxx" + token); conn.connect(); DataOutputStream out = new DataOutputStream(conn.getOutputStream()); //out.write(content.getBytes("UTF8")); // 刷新、關閉 out.flush(); out.close(); InputStream is = conn.getInputStream(); if (is != null) { ByteArrayOutputStream outStream = new ByteArrayOutputStream(); byte[] buffer = new byte[1024]; int len = 0; while ((len = is.read(buffer)) != -1) { outStream.write(buffer, 0, len); } is.close(); byte[] array = outStream.toByteArray(); result = new String(array, "utf-8"); return result; } return null; } /** * get方式請求服務器(https協議) * * @param url 請求地址 * @param content 參數 * @param token 編碼 * @return * @throws NoSuchAlgorithmException * @throws KeyManagementException * @throws IOException */ public String get(String url, String content, String token) throws NoSuchAlgorithmException, KeyManagementException, IOException { String result = ""; SSLContext sc = SSLContext.getInstance("SSL"); sc.init(null, new TrustManager[]{new TrustAnyTrustManager()}, new java.security.SecureRandom()); URL httpUrl = new URL(url); HttpsURLConnection conn = (HttpsURLConnection) httpUrl.openConnection(); conn.setRequestMethod("GET"); conn.setSSLSocketFactory(sc.getSocketFactory()); conn.setHostnameVerifier(new TrustAnyHostnameVerifier()); conn.setDoOutput(true); conn.setRequestProperty("Content-Type", "application/json; charset=utf-8"); //conn.setRequestProperty("Authorization", "xxxxxx" + token); conn.connect();
//get方法與post方法除了conn.setRequestMethod("GET")這句不一樣外,關於DataOutputStream out的幾行一定要刪除,否則就會報405的錯誤 InputStream is = conn.getInputStream(); if (is != null) { ByteArrayOutputStream outStream = new ByteArrayOutputStream(); byte[] buffer = new byte[1024]; int len = 0; while ((len = is.read(buffer)) != -1) { outStream.write(buffer, 0, len); } is.close(); byte[] array = outStream.toByteArray(); result = new String(array, "utf-8"); return result; } return null; } }