使用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("參數(shù):" + sbuf.toString());
//A、與服務(wù)器建立 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ā)送報文至服務(wù)器
reqStream = request.getOutputStream();
reqStream.write(postData);
reqStream.close();
//D、接收服務(wù)器返回結(jié)果
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( "服務(wù)器不可達【" + 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("交易響應(yīng)結(jié)果:");
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");
}
}
結(jié)果如下:
交易請求地址:http://php.weather.sina.com.cn/iframe/index/w_cl.php
參數(shù):dfc=1&charset=utf-8&day=0&code=js&city=上海
交易響應(yīng)結(jié)果:
(function(){var w=[];w['上海']=[{s1:'陰',s2:'陰',f1:'yin',f2:'yin',t1:'17',t2:'14',p1:'≤3',p2:'≤3',
d1:'東北風(fēng)',d2:'東北風(fēng)'}];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上傳文件到服務(wù)器
- Android中使用HttpURLConnection實現(xiàn)GET POST JSON數(shù)據(jù)與下載圖片
- iOS開發(fā)中使用NSURLConnection類處理網(wǎng)絡(luò)請求的方法
- 談?wù)凧ava利用原始HttpURLConnection發(fā)送POST數(shù)據(jù)
- Android通過HttpURLConnection和HttpClient接口實現(xiàn)網(wǎng)絡(luò)編程
- java后臺調(diào)用HttpURLConnection類模擬瀏覽器請求實例(可用于接口調(diào)用)
- Android 中HttpURLConnection與HttpClient使用的簡單實例
- Android HttpURLConnection.getResponseCode()錯誤解決方法
相關(guān)文章
JavaScript計算值然后把值嵌入到html中的實現(xiàn)方法
下面小編就為大家?guī)硪黄狫avaScript計算值然后把值嵌入到html中的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10
如何在uni-app使用微軟的文字轉(zhuǎn)語音服務(wù)
有了語音識別,交流就會變得很簡單,下面這篇文章主要給大家介紹了關(guān)于如何在uni-app使用微軟的文字轉(zhuǎn)語音服務(wù)的相關(guān)資料,需要的朋友可以參考下2022-06-06
Bootstrap組件之下拉菜單,多級菜單及按鈕布局方法實例
這篇文章主要介紹了Bootstrap組件之下拉菜單,多級菜單及按鈕布局方法,結(jié)合完整實例形式分析了Bootstrap多級菜單布局相關(guān)樣式功能與具體使用技巧,需要的朋友可以參考下2017-05-05
由JavaScript技術(shù)實現(xiàn)的web小游戲(不含網(wǎng)游)
伴隨Ajax與網(wǎng)頁游戲的崛起,曾幾何時JavaScript也成了游戲開發(fā)時可供選擇的技術(shù)之一,文本 僅列舉數(shù)項由JavaScript技術(shù)實現(xiàn)的web小游戲(不含網(wǎng)游),聊作參考之用。2010-06-06
JavaScript變速動畫函數(shù)封裝添加任意多個屬性
這篇文章主要介紹了JavaScript變速動畫函數(shù)封裝添加任意多個屬性 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04

