使用UrlConnection實現(xiàn)后臺模擬http請求的簡單實例
使用UrlConnection實現(xiàn)后臺模擬http請求的簡單實例
這兩天在整理看httpclient,然后想自己用UrlConnection后臺模擬實現(xiàn)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、發(fā)送 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、發(fā)送報文至服務器 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是如何模擬后臺來發(fā)送http請求的,還有配置ssl、代理、自定義header等等,敬請期待吧。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- 利用HttpUrlConnection 上傳 接收文件的實現(xiàn)方法
- Java HttpURLConnection超時和IO異常處理
- iOS中使用NSURLConnection處理HTTP同步與異步請求
- Android中HttpURLConnection與HttpClient的使用與封裝
- Android程序開發(fā)通過HttpURLConnection上傳文件到服務器
- Android中使用HttpURLConnection實現(xiàn)GET POST JSON數據與下載圖片
- iOS開發(fā)中使用NSURLConnection類處理網絡請求的方法
- 談談Java利用原始HttpURLConnection發(fā)送POST數據
- Android通過HttpURLConnection和HttpClient接口實現(xiàn)網絡編程
- java后臺調用HttpURLConnection類模擬瀏覽器請求實例(可用于接口調用)
- Android 中HttpURLConnection與HttpClient使用的簡單實例
- Android HttpURLConnection.getResponseCode()錯誤解決方法
相關文章
ztree獲取當前選中節(jié)點子節(jié)點id集合的方法
這篇文章主要介紹了ztree獲取當前選中節(jié)點子節(jié)點id集合的方法,實例分析了ztree的方法transformToArray使用技巧,需要的朋友可以參考下2015-02-02JavaScript實現(xiàn)樓梯滾動特效(jQuery實現(xiàn))
這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)樓梯滾動特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09JS實現(xiàn)無縫循環(huán)marquee滾動效果
這篇文章主要為大家詳細介紹了JS實現(xiàn)無縫循環(huán)marquee滾動效果,兼容IE, FireFox, Chrome,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05JavaScript實現(xiàn)為事件句柄綁定監(jiān)聽函數的方法分析
這篇文章主要介紹了JavaScript實現(xiàn)為事件句柄綁定監(jiān)聽函數的方法,結合實例形式分析了javascript事件綁定的常用技巧與注意事項,需要的朋友可以參考下2017-11-11JavaScript實現(xiàn)將圖片地址轉成文件流并上傳
這篇文章主要為大家詳細介紹了如何使用JavaScript實現(xiàn)將圖片地址轉成文件流并上傳,感興趣的小伙伴可以跟隨小編一起學習一下2024-04-04