最近在做微信公众号开发,需要用java代码访问微信端接口来请求数据。

由于博主java的网络通信也不是很精通,只是粗略了解皮毛,等以后知识上来了再深入研究java的网络编程。

所以这篇文章就先介绍简单使用。

需要的jar包:

org.apache.httpcomponents

httpclient

4.3.6

org.apache.httpcomponents

httpcore

4.4

本篇博客分为几块部分:http的get、post请求,https的get、post请求

新建一个类HttpUtil:

public class HttpUtil {

private static PoolingHttpClientConnectionManager connMgr;

private static RequestConfig requestConfig;

private static final int MAX_TIMEOUT = 7000;

static {

// 设置连接池

connMgr = new PoolingHttpClientConnectionManager();

// 设置连接池大小

connMgr.setMaxTotal(100);

connMgr.setDefaultMaxPerRoute(connMgr.getMaxTotal());

RequestConfig.Builder configBuilder = RequestConfig.custom();

// 设置连接超时

configBuilder.setConnectTimeout(MAX_TIMEOUT);

// 设置读取超时

configBuilder.setSocketTimeout(MAX_TIMEOUT);

// 设置从连接池获取连接实例的超时

configBuilder.setConnectionRequestTimeout(MAX_TIMEOUT);

// 在提交请求之前 测试连接是否可用

configBuilder.setStaleConnectionCheckEnabled(true);

requestConfig = configBuilder.build();

}

}

http部分

get请求:

/**

* 发送 GET 请求(HTTP),不带输入数据

*

* @param url

* @return

*/

public static String doGet(String url) {

return doGet(url, new HashMap());

}

/**

* 发送 GET 请求(HTTP),K-V形式

*

* @param url

* @param params

* @return

*/

public static String doGet(String url, Map params) {

String apiUrl = url;

StringBuffer param = new StringBuffer();

//拼接get请求参数

int i = 0;

for (String key : params.keySet()) {

if (i == 0)

param.append("?");

else

param.append("&");

param.append(key).append("=").append(params.get(key));

i++;

}

//往url后面添加所有的请求参数

apiUrl += param;

String result = null;

//开始执行get请求,新建一个DefaultHttpClient对象

HttpClient httpclient = new DefaultHttpClient();

try {

//新建一个处理特定url的HttpGet对象

HttpGet httpGet = new HttpGet(apiUrl);

//执行请求,得到response对象

HttpResponse response = httpclient.execute(httpGet);

//获取响应状态码

int statusCode = response.getStatusLine().getStatusCode();

System.out.println("执行状态码 : " + statusCode);

HttpEntity entity = response.getEntity();

if (entity != null) {

//处理结果

// result = EntityUtils.toString(entity, "UTF-8");

InputStream instream = entity.getContent();

result = inputStream2String(instream, "UTF-8");

}

} catch (IOException e) {

e.printStackTrace();

}

return result;

}

inputStream2String:

private static String inputStream2String(InputStream is, String encode) {

String result = "";

try {

if (encode == null || encode.equals("")) {

// 默认以utf-8形式

encode = "utf-8";

}

BufferedReader reader = new BufferedReader(new InputStreamReader(is, encode));

StringBuffer sb = new StringBuffer();

while ((result = reader.readLine()) != null) {

sb.append(result).append("\n");

}

return sb.toString();

} catch (UnsupportedEncodingException e1) {

e1.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

return result;

}

post请求:

/**

* 发送 POST 请求(HTTP),不带输入数据

*

* @param apiUrl

* @return

*/

public static String doPost(String apiUrl) {

return doPost(apiUrl, new HashMap());

}

/**

* 发送 POST 请求(HTTP),K-V形式

*

* @param apiUrl

* API接口URL

* @param params

* 参数map

* @return

*/

public static String doPost(String apiUrl, Map params) {

//新建一个可以关闭的httpClient对象

CloseableHttpClient httpClient = HttpClients.createDefault();

String httpStr = null;

//新建一个处理特定请求的httpPost对象

HttpPost httpPost = new HttpPost(apiUrl);

//可以关闭的HttpResponse

CloseableHttpResponse response = null;

try {

//post请求设置

httpPost.setConfig(requestConfig);

//参数键值对对象(NameValuePair)的List

List pairList = new ArrayList(params.size());

for (Map.Entry entry : params.entrySet()) {

NameValuePair pair = new BasicNameValuePair(entry.getKey(), entry.getValue().toString());

pairList.add(pair);

}

//设置请求实体(参数)

httpPost.setEntity(new UrlEncodedFormEntity(pairList, Charset.forName("UTF-8")));

//执行请求

response = httpClient.execute(httpPost);

System.out.println(response.toString());

//获取响应实体

HttpEntity entity = response.getEntity();

//将响应实体以字符串形式变成结果

httpStr = EntityUtils.toString(entity, "UTF-8");

} catch (IOException e) {

e.printStackTrace();

} finally {

if (response != null) {

try {

//关闭流

EntityUtils.consume(response.getEntity());

} catch (IOException e) {

e.printStackTrace();

}

}

}

return httpStr;

}

/**

* 发送 POST 请求(HTTP),JSON形式

*

* @param apiUrl

* @param json

* json对象

* @return

*/

public static String doPost(String apiUrl, Object json) {

CloseableHttpClient httpClient = HttpClients.createDefault();

String httpStr = null;

HttpPost httpPost = new HttpPost(apiUrl);

CloseableHttpResponse response = null;

//大体过程和上面类似

try {

httpPost.setConfig(requestConfig);

StringEntity stringEntity = new StringEntity(json.toString(), "UTF-8");// 解决中文乱码问题

stringEntity.setContentEncoding("UTF-8");

//内容类型设置成json格式

stringEntity.setContentType("application/json");

httpPost.setEntity(stringEntity);

response = httpClient.execute(httpPost);

HttpEntity entity = response.getEntity();

System.out.println(response.getStatusLine().getStatusCode());

httpStr = EntityUtils.toString(entity, "UTF-8");

} catch (IOException e) {

e.printStackTrace();

} finally {

if (response != null) {

try {

EntityUtils.consume(response.getEntity());

} catch (IOException e) {

e.printStackTrace();

}

}

}

return httpStr;

}

HTTPS

我新建了一个类SSLClient:

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.HttpClientConnectionManager;

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

public class SSLClient extends DefaultHttpClient{

public SSLClient() throws Exception{

super();

SSLContext ctx = SSLContext.getInstance("TLS");

X509TrustManager tm = new X509TrustManager() {

public void checkClientTrusted(X509Certificate[] chain,

String authType) throws CertificateException {

}

public void checkServerTrusted(X509Certificate[] chain,

String authType) throws CertificateException {

}

public X509Certificate[] getAcceptedIssuers() {

return null;

}

};

ctx.init(null, new TrustManager[]{tm}, null);

//当前对象的管理

ClientConnectionManager ccm = this.getConnectionManager();

SchemeRegistry sr = ccm.getSchemeRegistry();//当前管理者的注册方案

//SSL工厂

SSLSocketFactory ssf = new SSLSocketFactory(ctx,SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);

sr.register(new Scheme("https", 443, ssf));//注册SSL

}

}

get请求:

/**

* 发送get请求

*

* @param url

* 链接地址

* @param charset

* 字符编码,若为null则默认utf-8

* @return

*/

public static String doGetSSL(String url, String charset) {

if (null == charset) {

charset = "utf-8";

}

HttpClient httpClient = null;

HttpGet httpGet = null;

String result = null;

try {

httpClient = new SSLClient();

httpGet = new HttpGet(url);

HttpResponse response = httpClient.execute(httpGet);

if (response != null) {

HttpEntity resEntity = response.getEntity();

if (resEntity != null) {

result = EntityUtils.toString(resEntity, charset);

}

}

} catch (Exception e) {

e.printStackTrace();

}

return result;

}

post请求:

/**

* 发送 SSL POST 请求(HTTPS),K-V形式

*

* @param apiUrl

* API接口URL

* @param params

* 参数map

* @return

*/

public static String doPostSSL(String apiUrl, Map params){

//会发生unable to find valid certification path to requested target异常

//CloseableHttpClient httpClient = HttpClients.custom().setSSLSocketFactory(createSSLConnSocketFactory())

//.setConnectionManager(connMgr).setDefaultRequestConfig(requestConfig).build();

HttpPost httpPost = new HttpPost(apiUrl);

CloseableHttpResponse response = null;

String httpStr = null;

SSLClient httpClient = null;

try {

httpClient = new SSLClient();

httpPost.setConfig(requestConfig);

List pairList = new ArrayList(params.size());

for (Map.Entry entry : params.entrySet()) {

NameValuePair pair = new BasicNameValuePair(entry.getKey(), entry.getValue().toString());

pairList.add(pair);

}

httpPost.setEntity(new UrlEncodedFormEntity(pairList, Charset.forName("utf-8")));

response = httpClient.execute(httpPost);

int statusCode = response.getStatusLine().getStatusCode();

if (statusCode != HttpStatus.SC_OK) {

return null;

}

HttpEntity entity = response.getEntity();

if (entity == null) {

return null;

}

httpStr = EntityUtils.toString(entity, "utf-8");

} catch (Exception e) {

e.printStackTrace();

} finally {

if (response != null) {

try {

EntityUtils.consume(response.getEntity());

} catch (IOException e) {

e.printStackTrace();

}

}

}

return httpStr;

}

/**

* 发送 SSL POST 请求(HTTPS),JSON形式

*

* @param apiUrl

* API接口URL

* @param json

* JSON对象

* @return

*/

public static String doPostSSL(String apiUrl, Object json) {

//CloseableHttpClient httpClient = HttpClients.custom().setSSLSocketFactory(createSSLConnSocketFactory())

//.setConnectionManager(connMgr).setDefaultRequestConfig(requestConfig).build();

HttpPost httpPost = new HttpPost(apiUrl);

CloseableHttpResponse response = null;

String httpStr = null;

SSLClient httpClient = null;

try {

httpClient = new SSLClient();

httpPost.setConfig(requestConfig);

StringEntity stringEntity = new StringEntity(json.toString(), "UTF-8");// 解决中文乱码问题

stringEntity.setContentEncoding("UTF-8");

stringEntity.setContentType("application/json");

httpPost.setEntity(stringEntity);

response = httpClient.execute(httpPost);

int statusCode = response.getStatusLine().getStatusCode();

if (statusCode != HttpStatus.SC_OK) {

return null;

}

HttpEntity entity = response.getEntity();

if (entity == null) {

return null;

}

httpStr = EntityUtils.toString(entity, "utf-8");

} catch (Exception e) {

e.printStackTrace();

} finally {

if (response != null) {

try {

EntityUtils.consume(response.getEntity());

} catch (IOException e) {

e.printStackTrace();

}

}

}

return httpStr;

}

以上方法都属于HttpUtil类中。

SSL部分不涉及具体证书的使用。

还有很多不懂请见谅。只知道大概怎么用,大体的意思是知道的。

代码片段:

java httpclient 使用_java之HttpClient简单使用相关推荐

  1. java post流_Java后端HttpClient Post提交文件流 及服务端接收文件流

    客户端将文件转换为流发送: 依赖的包: org.apache.httpcomponents httpclient 4.4 org.apache.httpcomponents httpmime 4.4 ...

  2. java rest客户端_Java中的简单REST客户端

    java rest客户端 如今,大多数用于与某些服务器通信的移动应用程序都使用REST服务. 这些服务也是JavaScript或jQuery的常用惯例. 现在,我知道在Java中为REST服务创建客户 ...

  3. java小知识_java小知识点简单回顾

    1.java的数据类型分为两种:简单类型和引用类型(数组.类以及接口).注意,java没有指针的说法,只有引用.简单类型的变量被声明时,存储空间也同时被分配:而引用类型声明变量(对象)时,仅仅为其分配 ...

  4. java foreach用法_Java十大简单性能优化

    以下是Java中最容易进行的10个性能优化: 1.使用StringBuilder 这几乎是所有Java代码中的默认设置.尽量避免+操作员.当然,您可能会争辩说它StringBuilder无论如何都是语 ...

  5. java 继承 冒号_java继承(extends)简单介绍

    继承相信很多人都有听说过,继承是面向对象的三个基本特征之一,下面的话就一起通过简单的文章来对java继承进行一下了解吧. 继承和现实生活中的"继承"的相似之处是保留一些父辈的特性, ...

  6. java 性能 优化_Java十大简单性能优化

    java 性能 优化 关于" web scale "这个流行词有很多炒作,人们花了很多时间来重新组织他们的应用程序体系结构,以使其系统"规模化". 但是什么是扩 ...

  7. java link 使用_Java数据结构之简单的连接点(link)实现方法示例

    本文实例讲述了Java数据结构之简单的连接点(link)实现方法.分享给大家供大家参考,具体如下: 一.概述: 链接点由:数据和指向下个数据的指针构成 如图: 二.简单实现: package com. ...

  8. java 重力脚本_Java中非常简单的脚本解析器

    我目前正在用Java进行一个小项目,我需要为我组成的机器人处理非常轻量级的脚本语言. 它不需要处理算术或任何复杂的功能,它只需要运行某些命令并处理if和while语句. 它可能看起来像这样: turn ...

  9. java网页截图_Java实现的简单网页截屏功能示例

    本文实例讲述了Java实现的简单网页截屏功能.分享给大家供大家参考,具体如下: package awtDemo; import java.awt.AWTException; import java.a ...

最新文章

  1. oracle 24365,深入解析:DBA_OBJECTS中的OBJECT_ID与DATA_OBJECT_ID的区别
  2. margin:0 auto;不能居中的原因
  3. NewLife.Net——管道处理器解决粘包
  4. [数据加密]GIS空间数据水印信息隐藏与加密技术方法[转]
  5. Bit-Z如何注册?【新手操作指南】
  6. sqlserver 事务例子
  7. win10计算机跑分,鲁大师如何跑分_鲁大师跑分详细教程
  8. [Unity][FlowCanvas] FlowScript 实现切换当前 CineMachine 摄像机
  9. c语言中0级和1级是什么意思啊,C语言处理指针问题中,二级指针与一级指针的区别是什么?...
  10. FLASH缓动导航制作方法.
  11. 细数2011TurboMail企业邮箱功能新飞跃
  12. java执行php代码块_Java示例讲解普通代码块以及静态代码块的执行顺序
  13. w3c 菜鸟mysql_w3c菜鸟
  14. 统计学从数据到结论(第四版) pdf
  15. 一句话说明sync, fsync, fdatasync的区别
  16. iOS从零开始学习socket编程——高并发多线程服务器
  17. 两个一维数组合成二维数组
  18. 无法定位程序输入点(cmake opencv_contrib,并配置后)
  19. C++之Queue容器初学
  20. centos虚拟机桥接网络配置服务器,CentOS7虚拟机桥接网络配置

热门文章

  1. signature=baf75cc8d5f0ec214457047717ac662f,ボトムアップ視覚注視とその連続性評価によるタスク呈示からのキー動作の抽出...
  2. Leetcode 柠檬水找零
  3. 基于SSM框架的人事管理系统设计
  4. 写博客?你需要哪些工具?
  5. ExtAspNet应用技巧(十一) - Subsonic配置与使用
  6. parseint与valueOf的区别
  7. 针对股票涨跌信息的一系列处理
  8. 快手财报:A面阳光、B面承压
  9. JFreeChart应用
  10. 好看的html登录遮罩提示加载中,jQuery炫酷页面预加载Loading特效插件