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

