Android HttpClient访问https接口
由于之前项目的接口需要安全测评,从HTTP变成了https,搞得Android这边也要变,原本以为和移动端没关系。事实错了。。。我用的是HttpClient来进行访问,没有进行证书验证则会报错。Android采用X509的证书信息机制,于是乎百度了一下,找到了解决方案。下面贴出工具类。
package test;
import java.io.IOException;
import java.net.Socket;
import java.net.UnknownHostException;
import java.security.KeyManagementException;
import java.security.KeyStore;
import java.security.KeyStoreException;
import java.security.NoSuchAlgorithmException;
import java.security.UnrecoverableKeyException;
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.HttpVersion;
import org.apache.http.client.HttpClient;
import org.apache.http.conn.ClientConnectionManager;
import org.apache.http.conn.scheme.PlainSocketFactory;
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;
import org.apache.http.impl.conn.tsccm.ThreadSafeClientConnManager;
import org.apache.http.params.BasicHttpParams;
import org.apache.http.params.HttpProtocolParams;
import org.apache.http.protocol.HTTP;
/*
* 信任所有证书
* */
public class HttpsUtil extends SSLSocketFactory{
SSLContext sslContext = SSLContext.getInstance("TLS");
@SuppressWarnings("deprecation")
public static HttpClient getMyHttpsClient() {
BasicHttpParams params = new BasicHttpParams();
HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
HttpProtocolParams.setContentCharset(params, HTTP.DEFAULT_CONTENT_CHARSET);
HttpProtocolParams.setUseExpectContinue(params, true);
SchemeRegistry schReg = new SchemeRegistry();
schReg.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
schReg.register(new Scheme("https", HttpsUtil.getSocketFactory(), 443));
ClientConnectionManager connMgr = new ThreadSafeClientConnManager(params, schReg);
return new DefaultHttpClient(connMgr, params);
}
public HttpsUtil(KeyStore truststore) throws NoSuchAlgorithmException, KeyManagementException, KeyStoreException, UnrecoverableKeyException {
super(truststore);
// Android 采用X509的证书信息机制
TrustManager tm = new X509TrustManager() {
@Override
public X509Certificate[] getAcceptedIssuers() {
return null;
}
// Create a trust manager that does not validate certificate chains
@Override
public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}
@Override
public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}
};
// Install the all-trusting trust manager
sslContext.init(null, new TrustManager[]{tm}, null);
}
@Override
public Socket createSocket() throws IOException {
return sslContext.getSocketFactory().createSocket();
}
@Override
public Socket createSocket(Socket socket, String host, int port, boolean autoClose) throws IOException, UnknownHostException {
return sslContext.getSocketFactory().createSocket(socket, host, port, autoClose);
}
public static SSLSocketFactory getSocketFactory() {
try {
KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
trustStore.load(null, null);
SSLSocketFactory factory = new HttpsUtil(trustStore);
//factory.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER); //允许所有主机的验证
return factory;
} catch (Exception e) {
e.getMessage();
return null;
}
}
}
工具类加上,直接在HttpClient初始化时赋予它就行。想这样:HttpClient httpclient =HttpsUtil.getMyHttpsClient();
初始化之后,就可以愉快的玩耍了,你之前HttpClient 怎么写就怎么写。get post都可以。不用怕访问https时会有报错了~~~当然,你直接用其他网络框架其实更加单。。。这里用的网络请求包是httpclient-4.5.jar 。
Android HttpClient访问https接口相关推荐
- 使用Java访问https接口javax.net.ssl.SSLHandshakeException: Received fatal alert: handshake_failure
jdk1.6,证书:SHA256+TLSv1.2 使用Java访问https://**************** 接口 控制台提示握手失败错误:javax.net.ssl.SSLHandsh ...
- android httpClient 支持HTTPS的访问方式
项目中Android https请求地址遇到了这个异常,javax.net.ssl.SSLPeerUnverifiedException: No peer certificate,是SSL协议中没有终 ...
- HttpClient访问https,设置忽略SSL证书验证
访问https时报错:sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provid ...
- Android客户端访问https出现问题(Trust anchor for certification path not found)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 遇到问题 一.问题分析 二.问题解决 总结 遇到问题 安卓客户端在调用https接口出现java.security.cert ...
- 使用Apache HttpComponents访问https接口(及老版本DefaultHttpClient deprecated)
2019独角兽企业重金招聘Python工程师标准>>> 前言 最近公司做了一组使用https协议证书加密的接口,为了能够使用户比较容易的使用这套接口,于是乎做了一个访问的例子程序.本 ...
- curl 访问https接口_微信/QQ域名检测-最新腾讯域名检测官方接口
背景 最近手里有个项目需要检测域名在微信里是否可以打开,如果被微信拦截,则需要进行下一步操作,所以需要判断域名的状态,但是微信官方并没有提供相关查询的方法,最后在网上找到了这个接口地址,分享给有需要的 ...
- android如何调用接口方法,在Android中访问WebService接口的方法
需要引入ksoap2-android-assembly-2.5.2-jar-with-dependencies.jar 代码如下: //WebService的命名空间 static final Str ...
- HttpClient 访问Https报错hostname in certificate didn't match:
错误: javax.net.ssl.SSLException:hostname in certificate didn't match:<**.**.****.com> != <*. ...
- HttpClient 忽略证书直接访问https站点
使用HttpClient访问https 站点时,如果Java没有导入该站点的证书的话,则会报如下错误: javax.net.ssl.SSLHandshakeException: sun.securit ...
最新文章
- DeepMind刚向星际争霸 II 的玩家们下了战书!你的对手可能是只AI,而你毫不知情...
- 谷歌相册_Google相册中的新存档功能是什么?
- 安装步骤_仓库货架的安装步骤
- 浪潮服务器2016销售额,Gartner:2016年前三季度浪潮服务器销售额中国第一
- sap甲方_带你走进SAP项目实施过程——前言
- qt 怎么设计个性化的滑块_滑块上走滑块模具结构设计,不一样的结构思维成就你的高薪职业...
- ASP.NET MVC3 快速入门-第四节 添加一个模型(转)
- java bigdecimal语法_Java Scanner hasNextBigDecimal()方法
- xrd连续扫描和步进扫描_多晶XRD步进扫描与连续扫描介绍
- Web敏感目录快速扫描软件 wwwscan
- 网站建设的流程及步骤是什么?
- 校长办公室管理系统c语言,【锦城故事】学软硬结合理论做智慧超群系统是锦城电子的必经之路...
- 人的转型才是关键 数字化时代你具备数字领导力么
- h5发送短信以及判别用户浏览器版本
- h5首页加载慢_为什么你做的H5开屏那么慢?H5首屏秒开方案探讨
- 常用的数据校验方式(奇偶,CRC,异或校验, LRC校验,累加和,MD5等校验)概念及源码
- java怎么开始编写代码_Java编程入门:开始用Java编写代码
- 帅某---近期总结(汤家凤考研视频总结)
- 沙尘暴ppt计算机,沙尘暴课件.ppt
- labview和matlab区别,labview和matlab区别