最近做在线支付时遇到需要以后台方式访问URL并获取其返回的数据的问题,在网络上g了一把,发现在常用的还是Apache的HttpClient。因为以经常要用到的原故,因此我对其进行了一些简单的封装,在此将代码贴一来,希望对有需要的朋友有所帮助,呵呵...

HttpUtils.java中有两个公共的静态方法,一个是URLPost,另一个是URLGet,一目了然,前者是提供POST方式提交数据的,后者是提供GET方式提交数据的。其中所需要传送的数据以Map的方式传入,剩下的工作就交给我这个HttpUtils吧!当然如果Http服务器端对所提交的数据的编码有要求的话,也没问题,你可以传入UTF-8或者GBK,当然大家还可自行增加。

下面是源代码,如果使用中有什么问题,欢迎大家提出。

  1. import java.io.IOException;
  2. import java.io.UnsupportedEncodingException;
  3. import java.net.URLEncoder;
  4. import java.util.Iterator;
  5. import java.util.Map;
  6. import java.util.Set;
  7. import org.apache.commons.httpclient.HttpClient;
  8. import org.apache.commons.httpclient.HttpException;
  9. import org.apache.commons.httpclient.HttpStatus;
  10. import org.apache.commons.httpclient.MultiThreadedHttpConnectionManager;
  11. import org.apache.commons.httpclient.methods.GetMethod;
  12. import org.apache.commons.httpclient.methods.PostMethod;
  13. import org.apache.commons.logging.Log;
  14. import org.apache.commons.logging.LogFactory;
  15. /**
  16. * HTTP工具类
  17. *
  18. * @author lixiangyang
  19. *
  20. */
  21. public class HttpUtils {
  22. private static Log log = LogFactory.getLog(HttpUtils.class);
  23. /**
  24. * 定义编码格式 UTF-8
  25. */
  26. public static final String URL_PARAM_DECODECHARSET_UTF8 = "UTF-8";
  27. /**
  28. * 定义编码格式 GBK
  29. */
  30. public static final String URL_PARAM_DECODECHARSET_GBK = "GBK";
  31. private static final String URL_PARAM_CONNECT_FLAG = "&";
  32. private static final String EMPTY = "";
  33. private static MultiThreadedHttpConnectionManager connectionManager = null;
  34. private static int connectionTimeOut = 25000;
  35. private static int socketTimeOut = 25000;
  36. private static int maxConnectionPerHost = 20;
  37. private static int maxTotalConnections = 20;
  38. private static HttpClient client;
  39. static{
  40. connectionManager = new MultiThreadedHttpConnectionManager();
  41. connectionManager.getParams().setConnectionTimeout(connectionTimeOut);
  42. connectionManager.getParams().setSoTimeout(socketTimeOut);
  43. connectionManager.getParams().setDefaultMaxConnectionsPerHost(maxConnectionPerHost);
  44. connectionManager.getParams().setMaxTotalConnections(maxTotalConnections);
  45. client = new HttpClient(connectionManager);
  46. }
  47. /**
  48. * POST方式提交数据
  49. * @param url
  50. *          待请求的URL
  51. * @param params
  52. *          要提交的数据
  53. * @param enc
  54. *          编码
  55. * @return
  56. *          响应结果
  57. * @throws IOException
  58. *          IO异常
  59. */
  60. public static String URLPost(String url, Map<String, String> params, String enc){
  61. String response = EMPTY;
  62. PostMethod postMethod = null;
  63. try {
  64. postMethod = new PostMethod(url);
  65. postMethod.setRequestHeader("Content-Type", "application/x-www-form-urlencoded;charset=" + enc);
  66. //将表单的值放入postMethod中
  67. Set<String> keySet = params.keySet();
  68. for(String key : keySet){
  69. String value = params.get(key);
  70. postMethod.addParameter(key, value);
  71. }
  72. //执行postMethod
  73. int statusCode = client.executeMethod(postMethod);
  74. if(statusCode == HttpStatus.SC_OK) {
  75. response = postMethod.getResponseBodyAsString();
  76. }else{
  77. log.error("响应状态码 = " + postMethod.getStatusCode());
  78. }
  79. }catch(HttpException e){
  80. log.error("发生致命的异常,可能是协议不对或者返回的内容有问题", e);
  81. e.printStackTrace();
  82. }catch(IOException e){
  83. log.error("发生网络异常", e);
  84. e.printStackTrace();
  85. }finally{
  86. if(postMethod != null){
  87. postMethod.releaseConnection();
  88. postMethod = null;
  89. }
  90. }
  91. return response;
  92. }
  93. /**
  94. * GET方式提交数据
  95. * @param url
  96. *          待请求的URL
  97. * @param params
  98. *          要提交的数据
  99. * @param enc
  100. *          编码
  101. * @return
  102. *          响应结果
  103. * @throws IOException
  104. *          IO异常
  105. */
  106. public static String URLGet(String url, Map<String, String> params, String enc){
  107. String response = EMPTY;
  108. GetMethod getMethod = null;
  109. StringBuffer strtTotalURL = new StringBuffer(EMPTY);
  110. if(strtTotalURL.indexOf("?") == -1) {
  111. strtTotalURL.append(url).append("?").append(getUrl(params, enc));
  112. } else {
  113. strtTotalURL.append(url).append("&").append(getUrl(params, enc));
  114. }
  115. log.debug("GET请求URL = \n" + strtTotalURL.toString());
  116. try {
  117. getMethod = new GetMethod(strtTotalURL.toString());
  118. getMethod.setRequestHeader("Content-Type", "application/x-www-form-urlencoded;charset=" + enc);
  119. //执行getMethod
  120. int statusCode = client.executeMethod(getMethod);
  121. if(statusCode == HttpStatus.SC_OK) {
  122. response = getMethod.getResponseBodyAsString();
  123. }else{
  124. log.debug("响应状态码 = " + getMethod.getStatusCode());
  125. }
  126. }catch(HttpException e){
  127. log.error("发生致命的异常,可能是协议不对或者返回的内容有问题", e);
  128. e.printStackTrace();
  129. }catch(IOException e){
  130. log.error("发生网络异常", e);
  131. e.printStackTrace();
  132. }finally{
  133. if(getMethod != null){
  134. getMethod.releaseConnection();
  135. getMethod = null;
  136. }
  137. }
  138. return response;
  139. }
  140. /**
  141. * 据Map生成URL字符串
  142. * @param map
  143. *          Map
  144. * @param valueEnc
  145. *          URL编码
  146. * @return
  147. *          URL
  148. */
  149. private static String getUrl(Map<String, String> map, String valueEnc) {
  150. if (null == map || map.keySet().size() == 0) {
  151. return (EMPTY);
  152. }
  153. StringBuffer url = new StringBuffer();
  154. Set<String> keys = map.keySet();
  155. for (Iterator<String> it = keys.iterator(); it.hasNext();) {
  156. String key = it.next();
  157. if (map.containsKey(key)) {
  158. String val = map.get(key);
  159. String str = val != null ? val : EMPTY;
  160. try {
  161. str = URLEncoder.encode(str, valueEnc);
  162. } catch (UnsupportedEncodingException e) {
  163. e.printStackTrace();
  164. }
  165. url.append(key).append("=").append(str).append(URL_PARAM_CONNECT_FLAG);
  166. }
  167. }
  168. String strURL = EMPTY;
  169. strURL = url.toString();
  170. if (URL_PARAM_CONNECT_FLAG.equals(EMPTY + strURL.charAt(strURL.length() - 1))) {
  171. strURL = strURL.substring(0, strURL.length() - 1);
  172. }
  173. return (strURL);
  174. }
  175. }

基于HttpClient的HttpUtils(后台访问URL)的更多相关文章

  1. nginx针对某个url限制ip访问,常用于后台访问限制【转】

    假如我的站点后台地址为: http://www.abc.net/admin.php 那么我想限制只有个别ip可以访问后台,那么需要在配置文件中增加: location ~ .*admin.* { al ...

  2. Spring RestTemplate: 比httpClient更优雅的Restful URL访问, java HttpPost with header

    { "Author": "tomcat and jerry", "url":"http://www.cnblogs.com/tom ...

  3. 基于shiro+jwt的真正rest url权限管理,前后端分离

    代码地址如下:http://www.demodashi.com/demo/13277.html bootshiro & usthe bootshiro是基于springboot+shiro+j ...

  4. 利用javascript Location访问Url,重定向,刷新页面

    网上转来了, 方便以后查询参考 本文介绍怎么使用javascript Location对象读和修改Url.怎么重载或刷新页面.javascript提供了许多方法访问,修改当前用户在浏览器中访问的url ...

  5. 基于SpringBoot的项目管理后台

    代码地址如下:http://www.demodashi.com/demo/13943.html 一.项目简介 在使用本项目之前,需要对SpringBoot,freemaker,layui,flyway ...

  6. 基于WCF 的远程数据库服务访问技术

    原文出处:http://www.lw80.cn/shuji/jsjlw/13588Htm.Htm摘要:本文介绍了使用WCF 建立和运行面向服务(SOA)的数据库服务的系统结构和技术要素,分析了WCF ...

  7. SpringCloud-Config通过Java访问URL对敏感词加密解密

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...

  8. 基于vue模块化开发后台系统——准备工作

    文章目录如下:项目效果预览地址项目开源代码基于vue模块化开发后台系统--准备工作基于vue模块化开发后台系统--构建项目基于vue模块化开发后台系统--权限控制 前言 本文章是以学习为主,练习一下v ...

  9. Django项目:CRM(客户关系管理系统)--84--74PerfectCRM实现CRM权限和权限组限制访问URL

    #models.py # ————————01PerfectCRM基本配置ADMIN———————— from django.db import models # Create your models ...

随机推荐

  1. nyoj 光棍的yy

    655-光棍的yy 内存限制:64MB 时间限制:1000ms Special Judge: Noaccepted:2 submit:3 题目描述: yy经常遇见一个奇怪的事情,每当他看时间的时候总会 ...

  2. ThinkPHP5 控制器中怎么实现 where id = 2 or id = 3 这个查询语句?

    使用 whereOr whereIn();  (来自 ★C̶r̶a̶y̶o̶n-杭州 ) 为什么不用数组啊,array('eq', array(1,2),'or') (来自 supler)

  3. tomcat源码阅读之单点登录

    一.SSO概念: 单点登录,Single Sign-On,简写为 SSO,是一个用户认证的过程,允许用户一次性进行认证后,就可访问系统中不同的应用:而无需要访问每个应用时,都重新输入用户和密码. 实现 ...

  4. oracle单表选择率(selectivity)——计算执行计划的基数

    CBO优化器是基于对当前经过特定测试的数据集中预期的行比率估计来计算基数的.此处的行数之比是一个数值,称为选择率(selectivity).得到选择率之后,将其与输入行数进行简单相乘既可得到基数. 在 ...

  5. golang 如何判断变量的类型

    本文介绍两种用于判断变量类型的方式. 方法一 package main import ( "fmt" ) func main() { v1 := "123456" ...

  6. GitHub10岁之际HanLP自然语言处理包用户量跃居榜首

    在本周,GitHub终于度过了属于它自己的十周岁生日.这个在2008年由3个来自旧金山的年轻人创建的基于Git的代码托管网站,先后超越了元老级的SourceForge和背景强大的Google Code ...

  7. OpenWrt在没有Luci时刷机

    scp上传bin文件到root文件夹下. sysupgrade openwrt-ar71xx-generic-dragino2-squashfs-sysupgrade.bin 等待重启

  8. sql存储过程输出

    1.存储过程写法 create procedure [dbo].[Y_GetICBillNo] @IsSave smallint, @FBillType int, @BillID VARCHAR (5 ...

  9. 学习 ASP.NET MVC

    http://www.cnblogs.com/gaoweipeng/category/203080.html http://blog.csdn.net/liu_ben_qian/article/det ...

  10. springMVC学习(7)-springMVC校验

    一.校验理解: 对于安全要求较高点建议在服务端进行校验. 控制层conroller:校验页面请求的参数的合法性.在服务端控制层conroller校验,不区分客户端类型(浏览器.手机客户端.远程调用) ...