詳解js跨域請求的兩種方式,支持post請求
JSONP實現跨域
常用的jquery實現跨域調用
$.ajax({
url: "http://127.0.0.1/~chenjiebin/mycode/php/crossdomain/index.php",
dataType: "jsonp",
jsonp: "callback",
context: document.body,
success: function(data) {
console.log(data);
}
});
這個調用實際上的實現原理是
在網頁中構造一個script標簽,將src設置為對應的url,并增加上相應的callback參數,形如如下格式:
<script src="http://127.0.0.1/~chenjiebin/mycode/php/crossdomain/index.php?callback=jQuery211018970995225637144_1465350372062&_=1465350372063"></script>
請求的服務端代碼如下:
$data = json_encode(array("id" => "1", "name" => "tom"));
$callback = $_GET["callback"];
echo $callback . "(" . $data . ")";
實際上最后返回的內容就是一段js代碼:
jQuery211018970995225637144_1465350372062({"id":"1","name":"tom"})
當瀏覽器獲取到該段js代碼后就會執(zhí)行這個函數,從而實現回調ajax請求時設置的success方法。
jsonp實現的缺點
了解了原理后,就知道jsonp實現的跨域方式不支持post請求,只能支持get請求。但是如果需要支持post請求該怎么辦呢?下面談下服務器端設置的方式。
服務端設置支持跨域
主要是Access-Control-Allow-Origin頭參數,該參數用來指定允許哪個來源的域請求。服務端代碼如下:
// 表示支持所有來源的域進行請求
// 實際在操作過程中可以設置為指定域
header('Access-Control-Allow-Origin:*');
$data = json_encode(array("id" => "1", "name" => "tom"));
echo $data;
對應的js代碼:
$.ajax({
type: "POST",
url: "http://127.0.0.1/~chenjiebin/mycode/php/crossdomain/header.php",
dataType: "json",
success: function(data) {
console.log(data);
}
});
可以支持post請求。
小結
實際上個人并不是特別喜歡用跨域請求的方式,可能會帶來一些不可預見的安全問題。比較習慣的方式通過本域下的服務端和跨域的源服務器進行交互。
- Nodejs Post請求報socket hang up錯誤的解決辦法
- nodejs實現HTTPS發(fā)起POST請求
- Angularjs中$http以post請求通過消息體傳遞參數的實現方法
- 輕松創(chuàng)建nodejs服務器(10):處理POST請求
- JSP、Servlet中get請求和post請求的區(qū)別總結
- JS獲取url參數,JS發(fā)送json格式的POST請求方法
- linux shell中curl 發(fā)送post請求json格式問題的處理方法
- nodejs使用http模塊發(fā)送get與post請求的方法示例
- java模擬post請求發(fā)送json的例子
- JS實現使用POST方式發(fā)送請求
相關文章
JavaScript中你不知道的Object.entries用法
大家應該都知道,Object.entries()方法返回一個給定對象自身可枚舉屬性的鍵值對數組,其排列與使用 for...in 循環(huán)遍歷該對象時返回的順序一致,這篇文章主要給大家介紹了關于JavaScript中你不知道的Object.entries用法的相關資料,需要的朋友可以參考下2021-10-10
event.keyCode鍵碼值表 附只能輸入特定的字符串代碼
非常不錯的應用,讓文本框里只能輸入money大家看下具體的實現代碼,真是只有想到,原理很簡單。2009-05-05

