이 기사에서는 주로 HttpClient를 사용하여 HTTPS 인터페이스 호출을 수행하는 방법을 소개합니다. 관심이 있는 경우 알아보실 수 있습니다.
이 기사에서는 HttpClient를 사용하여 HTTPS 인터페이스 호출을 수행하는 JAVA 방법을 소개합니다. 자세한 내용은 다음과 같습니다.
1. 인증서가 필요하지 않도록 클래스를 사용하여 DefaultHttpClient 클래스를 상속하고 확인 프로세스를 무시합니다.
import java.security.cert.CertificateException; import java.security.cert.X509Certificate; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManager; import javax.net.ssl.X509TrustManager; import org.apache.http.conn.ClientConnectionManager; import org.apache.http.conn.scheme.Scheme; import org.apache.http.conn.scheme.SchemeRegistry; import org.apache.http.conn.ssl.SSLSocketFactory; import org.apache.http.impl.client.DefaultHttpClient; /** * 用于进行Https请求的HttpClient * @ClassName: SSLClient * @Description: TODO * @author Devin <xxx> * @date 2017年2月7日 下午1:42:07 * */ public class SSLClient extends DefaultHttpClient { public SSLClient() throws Exception{ super(); SSLContext ctx = SSLContext.getInstance("TLS"); X509TrustManager tm = 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; } }; ctx.init(null, new TrustManager[]{tm}, null); SSLSocketFactory ssf = new SSLSocketFactory(ctx,SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER); ClientConnectionManager ccm = this.getConnectionManager(); SchemeRegistry sr = ccm.getSchemeRegistry(); sr.register(new Scheme("https", 443, ssf)); } }
2. HttpClient를 사용하여 게시물 요청을 보내는 도구 클래스를 만듭니다
import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.StatusLine; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpPost; import org.apache.http.entity.StringEntity; import org.apache.http.message.BasicHeader; import org.apache.http.util.EntityUtils; /** * 利用HttpClient进行post请求的工具类 * @ClassName: HttpClientUtil * @Description: TODO * @author Devin <xxx> * @date 2017年2月7日 下午1:43:38 * */ public class HttpClientUtil { @SuppressWarnings("resource") public static String doPost(String url,String jsonstr,String charset){ HttpClient httpClient = null; HttpPost httpPost = null; String result = null; try{ httpClient = new SSLClient(); httpPost = new HttpPost(url); httpPost.addHeader("Content-Type", "application/json"); StringEntity se = new StringEntity(jsonstr); se.setContentType("text/json"); se.setContentEncoding(new BasicHeader("Content-Type", "application/json")); httpPost.setEntity(se); HttpResponse response = httpClient.execute(httpPost); if(response != null){ HttpEntity resEntity = response.getEntity(); if(resEntity != null){ result = EntityUtils.toString(resEntity,charset); } } }catch(Exception ex){ ex.printStackTrace(); } return result; } }
3. 코드를 테스트합니다
public static void main(String[] args){ String url = "https://192.168.1.101/xxx"; String jsonStr = "{xxx}"; String httpOrgCreateTestRtn = HttpClientUtil.doPost(url, jsonStr, "utf-8"); }
위 내용은 Java가 HttpClient를 사용하여 HTTPS 인터페이스를 호출하는 방법의 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!