Java編程Post數(shù)據(jù)請求和接收代碼詳解
這兩天在做http服務(wù)端請求操作,客戶端post數(shù)據(jù)到服務(wù)端后,服務(wù)端通過request.getParameter()進(jìn)行請求,無法讀取到數(shù)據(jù),搜索了一下發(fā)現(xiàn)是因為設(shè)置為text/plain模式才導(dǎo)致讀取不到數(shù)據(jù)
urlConn.setRequestProperty("Content-Type","text/plain; charset=utf-8");
若設(shè)置為以下方式,則通過request.getParameter()可以讀取到數(shù)據(jù)
urlConn.setRequestProperty("Content-Type","application/x-www-form-urlencoded");
enctype的三種編碼
form表單中enctype屬性可以用來控制對表單數(shù)據(jù)的發(fā)送前的如何進(jìn)行編碼,即在發(fā)送到服務(wù)器之前,所有字符都會進(jìn)行編碼(空格轉(zhuǎn)換為"+"加號,特殊符號轉(zhuǎn)換為ASCIIHEX值)。默認(rèn)是application/x-www-form-urlencoded。
multipart/form-data用于發(fā)送二進(jìn)制的文件,其他兩種類型不能用于發(fā)送文件
text/plain用于發(fā)送純文本內(nèi)容,不對特殊字符進(jìn)行編碼,一般用于email之類的。
application/x-www-form-urlencoded和text/plain的區(qū)別簡單講就是一個發(fā)送html內(nèi)容,一個發(fā)送純文本內(nèi)容
application/x-www-form-urlencoded在發(fā)送前編碼所有字符(默認(rèn))
multipart/form-data不對字符編碼。在使用包含文件上傳控件的表單時,必須使用該值。
text/plain空格轉(zhuǎn)換為"+"加號,但不對特殊字符編碼。
當(dāng)定義enctype為application/x-www-form-urlencoded時,使用以下方式接收數(shù)據(jù)
request.getParameter(參數(shù)名);
當(dāng)定義enctype為text/plain時,使用以下方式接收數(shù)據(jù)
// 接收請求數(shù)據(jù) BufferedReader reader = request.getReader(); char[] buf = new char[512]; int len = 0; StringBuffer contentBuffer = new StringBuffer(); while ((len = reader.read(buf)) != -1) { contentBuffer.append(buf, 0, len); } String content = contentBuffer.toString(); if(content == null){ content = ""; }
post與get
tp請求在所有的編程語言中幾乎都是支持的,我們常用的兩種為:GET,POST請求。一般情況下,發(fā)送一個GET請求都很簡單,因為參數(shù)直接放在請求的URL上,對于POST請求,由于其數(shù)據(jù)是在消息體中發(fā)送出去的,所以相對來說要麻煩一點(diǎn),再涉及到需要發(fā)送文件等二進(jìn)制的數(shù)據(jù)類型,就更需要更多的處理。
post和get可以通過鍵值對的方式進(jìn)行參數(shù)傳輸,服務(wù)端通過request.getparameter方式進(jìn)行請求獲取數(shù)據(jù)。
客戶端post數(shù)據(jù)到服務(wù)端,服務(wù)端接收處理
public class UrlConnection { @SuppressWarnings("finally") public static Boolean response(String url,String content) { String line = ""; String message = ""; String returnData = ""; Boolean postState = false; BufferedReader bufferedReader = null; try { URL urlObject = new URL(url); HttpURLConnection urlConn = (HttpURLConnection) urlObject.openConnection(); urlConn.setDoOutput(true); /*設(shè)定禁用緩存*/ urlConn.setRequestProperty("Pragma:", "no-cache"); urlConn.setRequestProperty("Cache-Control", "no-cache"); /*維持長連接*/ urlConn.setRequestProperty("Connection", "Keep-Alive"); /*設(shè)置字符集*/ urlConn.setRequestProperty("Charset", "UTF-8"); /*設(shè)定輸出格式為json*/ urlConn.setRequestProperty("Content-Type", "application/json;charset=utf-8"); /*設(shè)置使用POST的方式發(fā)送*/ urlConn.setRequestMethod("POST"); /*設(shè)置不使用緩存*/ urlConn.setUseCaches(false); /*設(shè)置容許輸出*/ urlConn.setDoOutput(true); /*設(shè)置容許輸入*/ urlConn.setDoInput(true); urlConn.connect(); OutputStreamWriter outStreamWriter = new OutputStreamWriter(urlConn.getOutputStream(),"UTF-8"); outStreamWriter.write(content); outStreamWriter.flush(); outStreamWriter.close(); /*若post失敗*/ if((urlConn.getResponseCode() != 200)){ returnData = "{\"jsonStrStatus\":0,\"processResults\":[]}"; message = "發(fā)送POST失?。?+ "code="+urlConn.getResponseCode() + "," + "失敗消息:"+ urlConn.getResponseMessage(); // 定義BufferedReader輸入流來讀取URL的響應(yīng) InputStream errorStream = urlConn.getErrorStream(); if(errorStream != null) { InputStreamReader inputStreamReader = new InputStreamReader(errorStream,"utf-8"); bufferedReader = new BufferedReader(inputStreamReader); while ((line = bufferedReader.readLine()) != null) { message += line; } inputStreamReader.close(); } errorStream.close(); System.out.println("發(fā)送失?。″e誤信息為:"+message); } else{ /*發(fā)送成功返回發(fā)送成功狀態(tài)*/ postState = true; // 定義BufferedReader輸入流來讀取URL的響應(yīng) InputStream inputStream = urlConn.getInputStream(); InputStreamReader inputStreamReader = new InputStreamReader(inputStream,"utf-8"); bufferedReader = new BufferedReader(inputStreamReader); while ((line = bufferedReader.readLine()) != null) { message += line; } returnData = message; inputStream.close(); inputStreamReader.close(); System.out.println("發(fā)送POST成功!返回內(nèi)容為:" + message); } } catch (Exception e) { e.printStackTrace(); } finally{ try { if (bufferedReader != null) { bufferedReader.close(); } } catch (IOException ex) { ex.printStackTrace(); } return postState; } } /*讀取request數(shù)據(jù)*/ public static String getRequestData(HttpServletRequest request) throws IOException{ BufferedReader reader = request.getReader(); char[] buf = new char[512]; int len = 0; StringBuffer contentBuffer = new StringBuffer(); while ((len = reader.read(buf)) != -1) { contentBuffer.append(buf, 0, len); } String content = contentBuffer.toString(); if(content == null){ content = ""; } return content; } }
總結(jié)
以上就是本文關(guān)于Java編程Post數(shù)據(jù)請求和接收代碼詳解的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
java線程間通信的通俗解釋及代碼示例
Java多線程之線程通信生產(chǎn)者消費(fèi)者模式及等待喚醒機(jī)制代碼詳解
Java多線程編程實現(xiàn)socket通信示例代碼
如有不足之處,歡迎留言指出。
上一篇:Java編程實現(xiàn)鄰接矩陣表示稠密圖代碼示例
欄 目:Java編程
下一篇:Java編程構(gòu)造方法與對象的創(chuàng)建詳解
本文標(biāo)題:Java編程Post數(shù)據(jù)請求和接收代碼詳解
本文地址:http://mengdiqiu.com.cn/a1/Javabiancheng/8417.html
您可能感興趣的文章
- 01-10Java咖啡館(1)——嘆咖啡
- 01-10Java Socket編程(三) 服務(wù)器Sockets
- 01-10Java進(jìn)階:Struts多模塊的技巧
- 01-10Java Socket編程(一) Socket傳輸模式
- 01-10Java Socket編程(二) Java面向連接的類
- 01-10Java運(yùn)行時多態(tài)性的實現(xiàn)
- 01-10Java經(jīng)驗點(diǎn)滴:處理沒有被捕獲的異常
- 01-10Java Socket編程(四) 重復(fù)和并發(fā)服務(wù)器
- 01-10Java中的浮點(diǎn)數(shù)分析
- 01-10面向?qū)ο缶幊?Java中的抽象數(shù)據(jù)類型


閱讀排行
本欄相關(guān)
- 01-10Java咖啡館(1)——嘆咖啡
- 01-10JVM的垃圾回收機(jī)制詳解和調(diào)優(yōu)
- 01-10Java Socket編程(三) 服務(wù)器Sockets
- 01-10Java進(jìn)階:Struts多模塊的技巧
- 01-10J2SE 1.5版本的新特性一覽
- 01-10Java Socket編程(一) Socket傳輸模式
- 01-10Java運(yùn)行時多態(tài)性的實現(xiàn)
- 01-10Java Socket編程(二) Java面向連接的類
- 01-10Java Socket編程(四) 重復(fù)和并發(fā)服務(wù)
- 01-10Java經(jīng)驗點(diǎn)滴:處理沒有被捕獲的異常
隨機(jī)閱讀
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10C#中split用法實例總結(jié)
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11ajax實現(xiàn)頁面的局部加載
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 04-02jquery與jsp,用jquery
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文