版权声明:本文为博主原创文章,未经博主允许不得转载。如需转载请声明:【转自 http://blog.csdn.net/xiaoxian8023 】
这两天在整理看httpclient,然后想自己用UrlConnection后台模拟实现Http请求,于是一个简单的小例子就新鲜出炉了(支持代理哦):
~~~
public class SimpleHttpTest {
public static String send(String urlStr, Map<String,String> map,String encoding){
String body="";
StringBuffer sbuf = new StringBuffer();
if(map!=null){
for (Entry<String,String> entry : map.entrySet()) {
sbuf.append(entry.getKey()).append("=").append(entry.getValue()).append("&");
}
if(sbuf.length()>0){
sbuf.deleteCharAt(sbuf.length()-1);
}
}
// 1、重新对请求报文进行 GBK 编码
byte[] postData = null;
try {
postData = sbuf.toString().getBytes(encoding);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
// 2、发送 HTTP(S) 请求
OutputStream reqStream = null;
InputStream resStream = null;
URLConnection request = null;
try {
System.out.println("交易请求地址:" + urlStr);
System.out.println("参数:" + sbuf.toString());
//A、与服务器建立 HTTP(S) 连接
URL url = null;
try {
Proxy proxy = new Proxy(java.net.Proxy.Type.HTTP,new InetSocketAddress("127.0.0.1", 8087));
url = new URL(urlStr);
request = url.openConnection(proxy);
request.setDoInput(true);
request.setDoOutput(true);
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
//B、指定报文头【Content-type】、【Content-length】 与 【Keep-alive】
request.setRequestProperty("Content-type", "application/x-www-form-urlencoded");
request.setRequestProperty("Content-length", String.valueOf(postData.length));
request.setRequestProperty("Keep-alive", "false");
request.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");
//C、发送报文至服务器
reqStream = request.getOutputStream();
reqStream.write(postData);
reqStream.close();
//D、接收服务器返回结果
ByteArrayOutputStream ms = null;
resStream = request.getInputStream();
ms = new ByteArrayOutputStream();
byte[] buf = new byte[4096];
int count;
while ((count = resStream.read(buf, 0, buf.length)) > 0) {
ms.write(buf, 0, count);
}
resStream.close();
body = new String(ms.toByteArray(), encoding);
} catch (UnknownHostException e) {
System.err.println( "服务器不可达【" + e.getMessage() + "】");
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (reqStream != null)
reqStream.close();
if (resStream != null)
resStream.close();
} catch (Exception ex) {
}
}
System.out.println("交易响应结果:");
System.out.println(body);
return body;
}
public static void main(String[] args) {
String url="http://php.weather.sina.com.cn/iframe/index/w_cl.php";
Map<String, String> map = new HashMap<String, String>();
map.put("code", "js");
map.put("day", "0");
map.put("city", "上海");
map.put("dfc", "1");
map.put("charset", "utf-8");
send(url, map,"utf-8");
}
}
~~~
结果如下:
~~~
交易请求地址:http://php.weather.sina.com.cn/iframe/index/w_cl.php
参数:dfc=1&charset=utf-8&day=0&code=js&city=上海
交易响应结果:
(function(){var w=[];w['上海']=[{s1:'阴',s2:'阴',f1:'yin',f2:'yin',t1:'17',t2:'14',p1:'≤3',p2:'≤3',d1:'东北风',d2:'东北风'}];var add={now:'2015-11-11 19:04:33',time:'1447239873',update:'北京时间11月11日17:10更新',error:'0',total:'1'};window.SWther={w:w,add:add};})();//0
~~~
代码中的步骤写的很明白了,如果你有心,还可以对该方法进行各种封装,方便使用。下篇我会分享一下httpclient是如何模拟后台来发送http请求的,还有配置ssl、代理、自定义header等等,敬请期待吧。
- 前言
- HttpClient3.x之Get请求和Post请求示例
- httpclient3.x中使用HTTPS的方法
- 简单的利用UrlConnection,后台模拟http请求
- 轻松把玩HttpClient之模拟post请求示例
- 轻松把玩HttpClient之配置ssl,采用绕过证书验证实现https
- 轻松把玩HttpClient之配置ssl,采用设置信任自签名证书实现https
- 轻松把玩HttpClient之设置代理,可以访问FaceBook
- 轻松把玩HttpClient之封装HttpClient工具类(一)(现有网上分享中的最强大的工具类)
- 轻松把玩HttpClient之封装HttpClient工具类(二),插件式配置HttpClient对象
- 轻松把玩HttpClient之封装HttpClient工具类(三),插件式配置Header
- 轻松把玩HttpClient之封装HttpClient工具类(四),单线程调用及多线程批量调用测试
- 轻松把玩HttpAsyncClient之模拟post请求示例
- 轻松把玩HttpClient之封装HttpClient工具类(五),携带Cookie的请求
- 轻松把玩HttpClient之封装HttpClient工具类(六),封装输入参数,简化工具类