国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > 建站經驗 > 正文

js實現跨域的方法實例詳解

2019-11-02 15:53:08
字體:
來源:轉載
供稿:網友

   本文實例講述了js實現跨域的方法。分享給大家供大家參考。具體分析如下:

  由于同源策略的限制,XMLHttpRequest只允許請求當前源(包含域名、協議、端口)的資源。

  json與jsonp的區別:

  JSON是一種數據交換格式,而JSONP是一種依靠開發人員創造出的一種非官方跨域數據交互協議。

  script標簽經常被用來加載不同域下的資源,可以繞過同源策略。(有src屬性的都可以獲取異域文件)。

  如果請求的這個遠程數據本身就是一段可執行的js,那么這些js會被執行(相當于eval)。

  方法一:

  利用script標簽請求( )

  在使用script標簽請求前,先進行回調函數的申明調用,

  ?

1 2 3 4 <script> function 回調函數名(data數據){ 。。。。 } </script> <script src="http://....jsp?callback=回調函數名"></script>

  使用JSON來傳遞javascript對象是一種最簡單的方式了,這樣的跨域通訊方式稱為JSONP。

  遠程服務器拼湊字符串:

  回調函數名( {"name1":"data1","name2","data2"} )

  這種以后臺拼湊json數據,利用回調函數傳參的形式返回給客戶端

  (可以直接調用相當于已經將獲取的字符串進行eval了處理)

  例如:

  ?

1 2 function databack(data){ alert(data.name1) } // 會輸出顯示"data1"

  方法二:

  jquery實現異域加載方法更為簡單(與ajax異步請求方式相同)

  ?

1 2 3 4 5 $.ajax({ type : "get", dataType:"json", success : function(data){ alert(data.name1) }; })

  或者簡寫形式

  ?

1 2 3 4 var url = "http://.....jsp?callback=?"; // 在jquery中此處的callback值可以為任意, // 因為jquery進行處理后都是利用success回調函數進行數據的接受; $.getJSON( url, function(data){ alert(data.name1) });

  方法三:

  ajax跨域之服務端代理

  在同源的后臺設置一個代理程序(proxy.jsp...);

  在服務器端與異域的服務器交互。

  jquery前臺傳輸數據:

  例如:

  ?

1 2 3 4 5 6 7 8 9 10 $.get(    'http://。。。.jsp', // 代理程序地址    {    name1 : "data1",    name2 : "data2"    },    function(data){    if(data == 1) alert('發送成功!');    } );
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 顺义区| 楚雄市| 九江市| 连南| 图们市| 钟祥市| 武胜县| 卫辉市| 宣武区| 安陆市| 托克逊县| 蒙山县| 金华市| 仁寿县| 黑水县| 班戈县| 贵州省| 大悟县| 博客| 沙坪坝区| 大宁县| 韩城市| 武汉市| 丹东市| 仙居县| 汉寿县| 雷州市| 和田市| 侯马市| 景宁| 梅河口市| 黔南| 迭部县| 桐梓县| 北安市| 四会市| 恭城| 湘阴县| 聂荣县| 鹿邑县| 东乡族自治县|