Https与Http类似,只不过Https一般是通过post请求服务器,但是Https与http不同的是Https与服务器会话是处于连接状态。http则发送请求后连接就会断开。
发送post请求代码:
String query = r4 + "&pass=" + r3; //请求参数
byte[] entitydata = query.getBytes();//得到实体数据
HttpsURLConnection urlCon = (new URL(ticketurl)).openConnection();
urlCon.setRequestProperty("Content-Type", "application/x-www-form-urlencoded;charset=UTF-8");
urlCon.setRequestProperty("Content-Length", String.valueOf(entitydata.length));
((HttpsURLConnection) urlCon).setRequestMethod("POST");
urlCon.setDoOutput(true);
urlCon.setDoInput(true);
urlCon.connect();

//把封装好的实体数据发送到输出流
OutputStream outStream = urlCon.getOutputStream();
outStream.write(entitydata);
outStream.flush();
outStream.close();

//服务器返回输入流并读写
BufferedReader in = new BufferedReader(new InputStreamReader(urlCon.getInputStream()));
String line;

while ((line = in.readLine()) != null) {
return line;
}
in.close();
另外使用HttpsURLConnection时需要实现HostnameVerifier 和 X509TrustManager,这两个实现是必须的,要不会报安全验证异常。然后初始化X509TrustManager中的SSLContext,为javax.net.ssl.HttpsURLConnection设置默认的SocketFactory和HostnameVerifier。代码如下:
private myX509TrustManager xtm = new myX509TrustManager();
private myHostnameVerifier hnv = new myHostnameVerifier();

public HttpsURLConnectionTest() {

//初始化X509TrustManager中的SSLContext
SSLContext sslContext = null;

try {
sslContext = SSLContext.getInstance("TLS");
X509TrustManager[] xtmArray = new X509TrustManager[] { xtm };
sslContext.init(null, xtmArray, new java.security.SecureRandom());
} catch (GeneralSecurityException gse) {

}

//为javax.net.ssl.HttpsURLConnection设置默认的SocketFactory和HostnameVerifier
if (sslContext != null) {
HttpsURLConnection.setDefaultSSLSocketFactory(sslContext.getSocketFactory());
}

HttpsURLConnection.setDefaultHostnameVerifier(hnv);
这样就不会报错了。

更多相关文章

  1. Android———利用JDBC连接服务器数据库
  2. Android单元测试,模拟http的get和post请求,服务器脚本使用php
  3. google的GCM推送使用简介
  4. 自带finish清除网络请求的Activity
  5. Android同步网络请求工具类HttpURLConnection
  6. android请求权限
  7. Activity的AsyncTask请求
  8. Volley的四大请求
  9. 使用Retrofit Https请求

随机推荐

  1. 【文档】五、Mysql Binlog事件结构
  2. g++ 连接 mysql 编译报错 /usr/bin/ld: c
  3. Mysql 查看及设置事物隔离级别
  4. mysql学习之路_外键
  5. 如何用mysql或Navicat实现流水号的插入
  6. 远程服务器CentOS7安装MySQL并用本地Navi
  7. 在mac中配置apache+php5.3+mysql的环境,修
  8. 如何在mysql中的两个值之间插入一个新值
  9. 主义通过扩展来破坏对实体的查询
  10. 新版MySql 5.6.20,安装后无法登陆的解决办