1. 程式人生 > >簡單的利用UrlConnection,後臺模擬http請求

簡單的利用UrlConnection,後臺模擬http請求

轉載地址:http://blog.csdn.net/xiaoxian8023/article/details/49785417

這兩天在整理看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