ajax中get与post请求的区别,ajax中get與post請求的區別

一、get()和post()基本區別

1.get是把參數數據隊列加到提交表單的ACTION屬性所指的URL中,值和表單內各個字段一一對應,在URL中可以看到。post是通過HTTP post機制,將表單內各個字段與其內容放置在HTML HEADER內一起傳送到ACTION屬性所指的URL地址。用戶看不到這個過程。

2.對於get方式,服務器端用Request.QueryString獲取變量的值,對於post方式,服務器端用Request.Form獲取提交的數據。兩種方式的參數都可以用Request來獲得。

3.get傳送的數據量較小,不能大於2KB。post傳送的數據量較大,一般被默認為不受限制。但理論上,因服務器的不同而異。

4.get安全性非常低,post安全性較高。

5.

跟是一樣的,也就是說,method為get時action頁面后邊帶的參數列表會被忽視;而跟是不一樣的。

二、談Ajax的Get和Post的區別

1.Get方式用get方式可傳送簡單數據,但大小一般限制在1KB下,數據追加到url中發送(http的header傳送),也就是說,瀏覽器將各個表單字段元素及其數據按照URL參數的格式附加在請求行中的資源路徑后面。另外最重要的一點是,它會被客戶端的瀏覽器緩存起來,那么,別人就可以從瀏覽器的歷史記錄中,讀取到此客戶的數據,比如帳號和密碼等。因此,在某些情況下,get方法會帶來嚴重的安全性問題。

Ajax發送請求:如果是get請求send(參數)參數:必須是null或xhr.send();

get請求就不必要設置 xhr.setRequestHeader(header,value)

備注:如果xhr.send(參數);參數不為空情況下,在某些瀏覽器中會自動轉換成post請求方式 您可以通過request.getMethod();方法獲取請求的方式

實例:

functiongetAjax(){

//獲取xhr對象

varxhr = getXhr();

//規定請求類型

xhr.open("get","main.jsp?username=123",true);

//發送請求

xhr.send();

//處理服務器響應事件

xhr.onreadystatechange =function(){

//判讀是否處理完畢 與判讀服務器是否處理成功!

if(xhr.readyState==4 && xhr.status==200){

alert(xhr.responseText);

}

}

}

}

使用get方式需要注意

(1)對於get請求(或凡涉及到url傳遞參數的),被傳遞的參數都要先經(預編碼處理)encodeURIComponent方法處理.例:var url = "update.php?username=" +encodeURIComponent(username) + "&content=" +encodeURIComponent(content)+"&id=1" ;

2.Post方式:      當使用POST方式時,瀏覽器把各表單字段元素及其數據作為HTTP消息      的實體內容發送給Web服務器,而不是作為URL地址的參數進行傳遞,使用  POST方式傳遞的數據量要比使用GET方式傳送的數據量大的多

發送請求:如果是post請求send(參數)參數:參數可以是null或者

xhr.send()|send(帶有參數的)post請求在傳遞值的情況下必須 設置          xhr.setRequestHeader(header,value)

實例:

functionpostAjax(){

//獲取xhr對象

varxhr = getXhr();

//規定請求類型

xhr.open("post","main.jsp",true);

xhr.setRequestHeader("Content-Type",

"application/x-www-form-urlencoded")

//發送參數

xhr.send("username=345&pass=123");

//相應事件處理

xhr.onreadystatechange =function(){

//判讀是否處理完畢 與判讀服務器是否處理成功!

if(xhr.readyState==4 && xhr.status==200){

alert(xhr.responseText);

}

}

}

使用Post方式需注意:      (1).設置header的Context-Type為application/x-www-form-

urlencode確保服務器知道實體中有參數變量.通常使用XmlHttpRequest對象的

SetRequestHeader("Context-Type","application/x-www-form-urlencoded;")。例:

xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded")

(2).參數是名/值一一對應的鍵值對,每對值用&號隔開.如 var name=abc&sex=man

&age=18 注意var name=update.php?abc&sex=man&age=18以及var name=?abc&sex=man

&age=18的寫法都是錯誤的;

(3).參數在Send(參數)方法中發送,例: xhr.send(name); 如果是  get  方    式,直接 xmlHttp.send(null);

(4).服務器端請求參數區分Get與Post。如果是get方式則$username =               $_GET["username"]; 如果是post方式,則$username =                                      $_POST["username"];

總之,GET方式傳送數據量小,處理效率高,安全性低,會被緩存,而POST反之。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值