Java編程Post數(shù)據(jù)請求和接收代碼詳解
這兩天在做http服務端請求操作,客戶端post數(shù)據(jù)到服務端后,服務端通過request.getParameter()進行請求,無法讀取到數(shù)據(jù),搜索了一下發(fā)現(xiàn)是因為設置為text/plain模式才導致讀取不到數(shù)據(jù)
urlConn.setRequestProperty("Content-Type","text/plain; charset=utf-8");
若設置為以下方式,則通過request.getParameter()可以讀取到數(shù)據(jù)
urlConn.setRequestProperty("Content-Type","application/x-www-form-urlencoded");
enctype的三種編碼
form表單中enctype屬性可以用來控制對表單數(shù)據(jù)的發(fā)送前的如何進行編碼,即在發(fā)送到服務器之前,所有字符都會進行編碼(空格轉換為"+"加號,特殊符號轉換為ASCIIHEX值)。默認是application/x-www-form-urlencoded。
multipart/form-data用于發(fā)送二進制的文件,其他兩種類型不能用于發(fā)送文件
text/plain用于發(fā)送純文本內(nèi)容,不對特殊字符進行編碼,一般用于email之類的。
application/x-www-form-urlencoded和text/plain的區(qū)別簡單講就是一個發(fā)送html內(nèi)容,一個發(fā)送純文本內(nèi)容
application/x-www-form-urlencoded在發(fā)送前編碼所有字符(默認)
multipart/form-data不對字符編碼。在使用包含文件上傳控件的表單時,必須使用該值。
text/plain空格轉換為"+"加號,但不對特殊字符編碼。
當定義enctype為application/x-www-form-urlencoded時,使用以下方式接收數(shù)據(jù)
request.getParameter(參數(shù)名);
當定義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ā)送出去的,所以相對來說要麻煩一點,再涉及到需要發(fā)送文件等二進制的數(shù)據(jù)類型,就更需要更多的處理。
post和get可以通過鍵值對的方式進行參數(shù)傳輸,服務端通過request.getparameter方式進行請求獲取數(shù)據(jù)。
客戶端post數(shù)據(jù)到服務端,服務端接收處理
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);
/*設定禁用緩存*/
urlConn.setRequestProperty("Pragma:", "no-cache");
urlConn.setRequestProperty("Cache-Control", "no-cache");
/*維持長連接*/
urlConn.setRequestProperty("Connection", "Keep-Alive");
/*設置字符集*/
urlConn.setRequestProperty("Charset", "UTF-8");
/*設定輸出格式為json*/
urlConn.setRequestProperty("Content-Type", "application/json;charset=utf-8");
/*設置使用POST的方式發(fā)送*/
urlConn.setRequestMethod("POST");
/*設置不使用緩存*/
urlConn.setUseCaches(false);
/*設置容許輸出*/
urlConn.setDoOutput(true);
/*設置容許輸入*/
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的響應
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ā)送失敗!錯誤信息為:"+message);
} else{
/*發(fā)送成功返回發(fā)送成功狀態(tài)*/
postState = true;
// 定義BufferedReader輸入流來讀取URL的響應
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;
}
}
總結
以上就是本文關于Java編程Post數(shù)據(jù)請求和接收代碼詳解的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
Java多線程之線程通信生產(chǎn)者消費者模式及等待喚醒機制代碼詳解
如有不足之處,歡迎留言指出。
相關文章
詳解如何在Spring Boot啟動后執(zhí)行指定代碼
這篇文章主要介紹了在Spring Boot啟動后執(zhí)行指定代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06
SpringBoot返回long,前端接收進度丟失,@JsonSerialize不生效問題
這篇文章主要介紹了SpringBoot返回long,前端接收進度丟失,@JsonSerialize不生效問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
java實戰(zhàn)案例之用戶注冊并發(fā)送郵件激活/發(fā)送郵件驗證碼
現(xiàn)在很多的網(wǎng)站都提供有用戶注冊功能,當我們注冊成功之后就會收到封注冊網(wǎng)站的郵件,郵件里包含了我們的注冊的用戶名和密碼及激活賬戶的超鏈接等信息,這篇文章主要給大家介紹了關于java實戰(zhàn)案例之用戶注冊并發(fā)送郵件激活/發(fā)送郵件驗證碼的相關資料,需要的朋友可以參考下2021-09-09
Spring學習之開發(fā)環(huán)境搭建的詳細步驟
本篇文章主要介紹了Spring學習之開發(fā)環(huán)境搭建的詳細步驟,具有一定的參考價值,有興趣的可以了解一下2017-07-07

