Ⅰ java HttpPost怎麼傳遞參數
public class HttpURLConnectionPost {
/**
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
readContentFromPost();
}
public static void readContentFromPost() throws IOException {
// Post請求的url,與get不同的是不需要帶參數
URL postUrl = new URL("http://www.xxxxxxx.com");
// 打開連接
HttpURLConnection connection = (HttpURLConnection) postUrl.openConnection();
// 設置是否向connection輸出,因為這個是post請求,參數要放在
// http正文內,因此需要設為true
connection.setDoOutput(true);
// Read from the connection. Default is true.
connection.setDoInput(true);
// 默認是 GET方式
connection.setRequestMethod("POST");
// Post 請求不能使用緩存
connection.setUseCaches(false);
//設置本次連接是否自動重定向
connection.setInstanceFollowRedirects(true);
// 配置本次連接的Content-type,配置為application/x-www-form-urlencoded的
// 意思是正文是urlencoded編碼過的form參數
connection.setRequestProperty("Content-Type","application/x-www-form-urlencoded");
// 連接,從postUrl.openConnection()至此的配置必須要在connect之前完成,
// 要注意的是connection.getOutputStream會隱含的進行connect。
connection.connect();
DataOutputStream out = new DataOutputStream(connection
.getOutputStream());
// 正文,正文內容其實跟get的URL中 '? '後的參數字元串一致
String content = "欄位名=" + URLEncoder.encode("字元串值", "編碼");
// DataOutputStream.writeBytes將字元串中的16位的unicode字元以8位的字元形式寫到流裡面
out.writeBytes(content);
//流用完記得關
out.flush();
out.close();
//獲取響應
BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
String line;
while ((line = reader.readLine()) != null){
System.out.println(line);
}
reader.close();
//該乾的都幹完了,記得把連接斷了
connection.disconnect();
}

(1)post方法的參數放在哪裡擴展閱讀:
關於Java HttpURLConnection使用
public static String sendPostValidate(String serviceUrl, String postData, String userName, String password){
PrintWriter out = null;
BufferedReader in = null;
String result = "";
try {
log.info("POST介面地址:"+serviceUrl);
URL realUrl = new URL(serviceUrl);
// 打開和URL之間的連接
URLConnection conn = realUrl.openConnection();
HttpURLConnection httpUrlConnection = (HttpURLConnection) conn;
// 設置通用的請求屬性
httpUrlConnection.setRequestProperty("accept","*/*");
httpUrlConnection.setRequestProperty("connection", "Keep-Alive");
httpUrlConnection.setRequestProperty("user-agent","Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
httpUrlConnection.setRequestMethod("POST");
httpUrlConnection.setRequestProperty("Content-Type","application/json;charset=UTF-8");
Base64 base64 = new Base64();
String encoded = base64.encodeToString(new String(userName+ ":" +password).getBytes());
httpUrlConnection.setRequestProperty("Authorization", "Basic "+encoded);
// 發送POST請求必須設置如下兩行
httpUrlConnection.setDoOutput(true);
httpUrlConnection.setDoInput(true);
// 獲取URLConnection對象對應的輸出流
out = new PrintWriter(new OutputStreamWriter(httpUrlConnection.getOutputStream(),"utf-8"));
// 發送請求參數
out.print(postData);
out.flush();
// 定義BufferedReader輸入流來讀取URL的響應
in = new BufferedReader(new InputStreamReader(httpUrlConnection.getInputStream(),"utf-8"));
String line;
while ((line = in.readLine()) != null) {
result += line;
}
//
// if (!"".equals(result)) {
// BASE64Decoder decoder = new BASE64Decoder();
// try {
// byte[] b = decoder.decodeBuffer(result);
// result = new String(b, "utf-8");
// } catch (Exception e) {
// e.printStackTrace();
// }
// }
return result;
} catch (Exception e) {
log.info("調用異常",e);
throw new RuntimeException(e);
}
//使用finally塊來關閉輸出流、輸入流
finally{
try{
if(out!=null){
out.close();
}
if(in!=null){
in.close();
}
}
catch(IOException e){
log.info("關閉流異常",e);
}
}
}
}
Ⅱ 從http請求中 獲得請求參數 應該調用哪個方法
HTTP請求方式有兩種,一種是GET方式,請求參數會用「?」作為分隔符跟在請求資源後面;另一種是POST方式,請求參數放在了最後面的位置。
伺服器監聽到瀏覽器的鏈接,首先將HTTP請求信息保存下來,再進行解析。
// 請求信息的輸入流
private InputStream input;
//獲得HTTP請求信息,並解析出請求使用的是GET還是POST,然後調用相應的處理方法進行處理
public void parseInput(){
byte [] b = new byte[1024];
try {
input.read(b);
} catch (IOException e) {
LogInfo.error("讀取請求信息出錯"+e.getMessage());
return;
}
String inputStr = new String(b);
String type = inputStr.substring(0,inputStr.indexOf(" "));
if("GET".equals(type)){
parseGetString(inputStr);
}
else{
parsePostString(inputStr);
}
}
//路徑信息,http://localhost:8088/CCB?account=abc&pwd=123,其中/CCB表示pathInfo
private String pathInfo;
//請求資源路徑,pathInfo中最後一個斜桿後米啊的字元串,如/bank/CCB,其中/CCB表示urlPattern
private String urlPattern;
//請求參數,在Get請求中第一個問號後面的字元串,如account=abc&pwd=123
private String queryStr;
//解析GET請求
public void parseGetString(String getStr){
String allStr = getStr;
String info = allStr.substring(allStr.indexOf("/"),allStr.indexOf(" HTTP"));
int end = info.indexOf("?");
if(end == -1){
pathInfo = info;
}else{
pathInfo = info.substring(0,end);
queryStr = info.substring(end + 1);
}
urlPattern = pathInfo.substring(pathInfo.lastIndexOf("/"));
parseQueryInfo(queryStr);
}
//解析POST請求
public void parsePostString(String postStr){
String qStr = postStr.trim();
pathInfo = postStr.substring(postStr.indexOf("/"),postStr.indexOf(" HTTP"));
urlPattern = pathInfo.substring(pathInfo.lastIndexOf("/"));
queryStr = qStr.substring(qStr.lastIndexOf(System.getProperty("line.separator"))).trim();
parseQueryInfo(queryStr);
}
解析出請求資源路徑和請求參數就可以找到對應的資源發送給瀏覽器或根據請求參數做相應的處理,再將資源發送回去。
Ⅲ get和post請求的參數位置
1、post:
export function getRelatedAuthors(data) {
return request({
url: ${process.env.VUE_APP_KCMS_LITERATURE_API}${process.env.VUE_APP_KCMS_VERSION}/articles/relations/authors ,
method: 'post',
data: data
});
}
2、get:
(1)
export function getMagazineInfo(data) {
return request({
url: process.env.VUE_APP_KCMS_PUBLICATION_API +'knavibeta/' + process.env.VUE_APP_KCMS_VERSION +
/navi/${data.types}/${data.id}/detail ,
method: 'get',
params: {
group:data.group
}
});
}
(2)
export function getMagazineInfo(data) {
return request({
url: process.env.VUE_APP_KCMS_PUBLICATION_API +'knavibeta/' + process.env.VUE_APP_KCMS_VERSION +
/navi/${data.types}/${data.id}/detail?group=${} ,
method: 'get',
});
}
Ⅳ get和post數據提交到哪裡
表單的GET、POST提交方法,在不同角度看來各有區別。 一、表單的編寫人看來,GET方式的表單代碼是這樣的(表單1): ...其它參數 POST方式的表單代碼是這樣的(表單2): ...其它參數 還可以編寫下面的表單,同時提交GET和POST內容,例如(表單3)...
2016-03-28 回答者: 陽光上的橋 2個回答 4
Ⅳ Http的post請求資源路徑中可以加參數嗎
完全可以。
不過伺服器端獲取參數的方式不一樣!
Ⅵ http post 怎麼傳參數
POST 傳遞數據 : 創建一個 HttpPost 對象, 使用要連接的uri 創建, 參數放在一個 NameValuePair 數組中, 這個很重要, 這個NameValuePair 可以直接存放要傳遞的鍵值對;
Ⅶ ESTAPI:POSTrequest的參數從哪傳
使用post的時候一樣能從url中獲取參數,正規的做法是把參數放到body中。舉個例子,假設用的https的話,把參數放到url中,別人抓包是可以看到的,但是放到body中抓包就只能看到加密後的數據了。
Ⅷ POST的跨域原理解析及GET和POST的區別
但是也是因為瀏覽器同源策略的原因,前端頁面不能跨域請求所需資源
但是在日常的WEB開發中,需要進行跨域請求,常用有兩種方式可以跨域請求所需資源
1:JSONP
JSONP是伺服器與客戶端跨源通信的常用方法。最大特點就是簡單適用,老式瀏覽器全部支持,
伺服器改造非常小。
JSONP的原理是利用script標簽的src屬性可以進行不受同源策略的限制,進行跨域請求數據的屬性,在
HTML頁面中添加一個script標簽,向伺服器發送請求,伺服器收到請求後,返回數據,
將數據放在指定的回調函數中,回調函數中可以對數據進行操作
2:GET、POST
CORS是W3C標准,它允許瀏覽器向跨源伺服器發送AJAX請求,當瀏覽器發送請求的時候,會在請求頭自動添加上origin欄位,值為發送請求的頁面的所在域名,請求到達伺服器,伺服器會根據這個欄位校驗,如果這個源不在許可范圍內,會有一個正常的響應,但是響應頭部沒有Access-Control-Allow-Origin,瀏覽器報拋出一個錯誤,會被xhr的onerror函數捕獲,但是HTTP的狀態碼也有可能是200;如果請求的類型是PUT或者DELETE等特殊的請求方法,或者content-type:application/json,那麼,這個請求為非簡單請求,瀏覽器會在發送正式請求前先發送一個預檢請求,預檢請求中的請求頭部信息除了origin源欄位以外,還有Access-Control-Allow—Method和Access-Control-Allow—Header,預檢請求是一個OPTION類型的請求,只要服務端通過了預檢請求,之後的請求就和簡單請求是一樣的
GET、POST是ajax請求,ajax請求是基於XMLHttpRequest對象的跨域請求方式(低版本的ie是
ActiveXObject對象),XMLHttpRequest是ajax的核心機制,
它是一種支持非同步請求的技術。簡單的說,也就是javascript可以及時向伺服器提出請求和處理響應,
而不阻塞用戶。達到無刷新的效果。
GET和POST的區別:
1.post更安全(不會作為url的一部分,不會被緩存、保存在伺服器日誌、以及瀏覽器瀏覽記錄中)
2.post發送的數據量更大(get有url長度限制)
3.post能發送更多的數據類型(get只能發送ASCII字元)
4.post比get慢
5.get是冪等的,而post不是冪等的
6.get可以被緩存,post不可以被緩存
因為get請求的請求參數是放在header中(添加在鏈接後面),而post請求的參數是放在body中,其實url的長度限制不是get和post所決定的,而是瀏覽器有所限制,和get、post沒有基本沒有關系
get和post相比,要快,是因為get和post的請求過程不同,不多前三步都是一樣的,都是要先經過和伺服器的三次握手:
1.瀏覽器請求tcp連接(第一次握手)
2.伺服器答應進行tcp連接(第二次握手)
3.瀏覽器確認,並發送get請求頭和數據(第三次握手,這個報文比較小,所以http會在此時進行第一次數據發送)
get請求在第四步就會接收到了伺服器返回的數據,而post請求在第四步是接收到伺服器發送的100 continue指令,客戶端在發送數據請求服務端,服務端才會去返回數據,
就是說POST比GET多進行了一次客戶端和伺服器的打交道,GET請求產生了一個TCP數據包,而POST請求產生了兩個TCP數據包