HTTPS请求实现框架
2015-09-29 11:21
435 查看
HTTPS主要用于安全传输数据,从代码的角度来看,HTTPS主要使用了X509的方式进行了加密,至于密钥(证书)在什么地方,可能在购买HTTPS服务的时候被统一放置在DNS服务器之类的地方了吧(纯推测):
package com.sahadev;
import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.URL;
import java.security.SecureRandom;
import java.security.cert.X509Certificate;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.KeyManager;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.X509TrustManager;
import org.apache.http.conn.ssl.AllowAllHostnameVerifier;
public class HttpClient {
private static final AllowAllHostnameVerifier HOSTNAME_VERIFIER = new AllowAllHostnameVerifier();
private static X509TrustManager xtm = new X509TrustManager() {
public void checkClientTrusted(X509Certificate[] chain, String authType) {
}
public void checkServerTrusted(X509Certificate[] chain, String authType) {
}
public X509Certificate[] getAcceptedIssuers() {
return null;
}
};
private static X509TrustManager[] xtmArray = new X509TrustManager[] { xtm };
private static HttpsURLConnection conn = null;
public static String sendHttpsPost(String path, String params) throws Exception {
// 组拼实体数据
byte[] entity = params.getBytes("UTF-8");
URL url = new URL(path);
conn = (HttpsURLConnection) url.openConnection();
if (conn instanceof HttpsURLConnection) {
// Trust all certificates
SSLContext context = SSLContext.getInstance("TLS");
context.init(new KeyManager[0], xtmArray, new SecureRandom());
SSLSocketFactory socketFactory = context.getSocketFactory();
((HttpsURLConnection) conn).setSSLSocketFactory(socketFactory);
((HttpsURLConnection) conn).setHostnameVerifier(HOSTNAME_VERIFIER);
}
conn.setConnectTimeout(5 * 1000);
conn.setReadTimeout(30000);
conn.setDoInput(true);
conn.setDoOutput(true);// 允许输出数据
conn.setUseCaches(false);
conn.setRequestMethod("POST");
conn.setRequestProperty("Content-Type", "application/json");
conn.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows; U; Windows NT 6.1; zh-CN; rv:1.9.2.6)");
OutputStream outStream = new DataOutputStream(conn.getOutputStream());
outStream.write(entity);
outStream.flush();
outStream.close();
BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream()));
StringBuffer sb = new StringBuffer();
String line;
while ((line = br.readLine()) != null) {
sb.append(line);
}
return sb.toString();
}
public static void closeConnection() {
if (conn != null)
conn.disconnect();
}
}
package com.sahadev;
import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.URL;
import java.security.SecureRandom;
import java.security.cert.X509Certificate;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.KeyManager;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.X509TrustManager;
import org.apache.http.conn.ssl.AllowAllHostnameVerifier;
public class HttpClient {
private static final AllowAllHostnameVerifier HOSTNAME_VERIFIER = new AllowAllHostnameVerifier();
private static X509TrustManager xtm = new X509TrustManager() {
public void checkClientTrusted(X509Certificate[] chain, String authType) {
}
public void checkServerTrusted(X509Certificate[] chain, String authType) {
}
public X509Certificate[] getAcceptedIssuers() {
return null;
}
};
private static X509TrustManager[] xtmArray = new X509TrustManager[] { xtm };
private static HttpsURLConnection conn = null;
public static String sendHttpsPost(String path, String params) throws Exception {
// 组拼实体数据
byte[] entity = params.getBytes("UTF-8");
URL url = new URL(path);
conn = (HttpsURLConnection) url.openConnection();
if (conn instanceof HttpsURLConnection) {
// Trust all certificates
SSLContext context = SSLContext.getInstance("TLS");
context.init(new KeyManager[0], xtmArray, new SecureRandom());
SSLSocketFactory socketFactory = context.getSocketFactory();
((HttpsURLConnection) conn).setSSLSocketFactory(socketFactory);
((HttpsURLConnection) conn).setHostnameVerifier(HOSTNAME_VERIFIER);
}
conn.setConnectTimeout(5 * 1000);
conn.setReadTimeout(30000);
conn.setDoInput(true);
conn.setDoOutput(true);// 允许输出数据
conn.setUseCaches(false);
conn.setRequestMethod("POST");
conn.setRequestProperty("Content-Type", "application/json");
conn.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows; U; Windows NT 6.1; zh-CN; rv:1.9.2.6)");
OutputStream outStream = new DataOutputStream(conn.getOutputStream());
outStream.write(entity);
outStream.flush();
outStream.close();
BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream()));
StringBuffer sb = new StringBuffer();
String line;
while ((line = br.readLine()) != null) {
sb.append(line);
}
return sb.toString();
}
public static void closeConnection() {
if (conn != null)
conn.disconnect();
}
}
相关文章推荐
- SpringMVC中StringHttpMessageConverter乱码处理
- CentOS 6与CentOS 7网络管理
- RTCPeerConnection介绍
- Xcode7 网络请求报错:The resource could not be loaded because the App Transport Security policy requires th
- HttpWebRequest用法
- android-async-http 异步网络请求客户端请求接口
- http协议
- linux透明防火墙接入fte 300 网络的问题
- Android发送GET和POST以及HttpClient发送POST请求给服务器响应
- HDU 5478 2015 ACM/ICPC 上海赛区网络赛1011 模运算+快速幂
- HTTP Basic Authentication认证的各种语言 后台用的
- RHCSA 系列(十一): 使用 firewalld 和 iptables 来控制网络流量
- HTTP Status 500 - java.lang.LinkageError: loader constraint violation: loader (instance of org/apach
- 列出rpm包内容和解压rpm包内容 http://www.51testing.com/html/57/28557-205195.html
- IIS 7完全攻略之日志记录配置(摘自网络)
- 浅谈HTTP中Get与Post的区别
- python登录认证HTTP并打印头信息
- 根据http头判断用户来源是GET还是POST
- HttpURLConnection与HttpClient区别及联系
- Apache httpd和JBoss构建高可用集群环境