<pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

          <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

          <p id="bbfd9"></p>

          <p id="bbfd9"><cite id="bbfd9"></cite></p>

            <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

            <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
            <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
            php語言

            PHP處理Ajax請求與Ajax跨域問題

            時間:2025-04-14 18:33:50 php語言 我要投稿
            • 相關推薦

            PHP處理Ajax請求與Ajax跨域問題

              這篇文章主要介紹了PHP處理Ajax請求與Ajax跨域問題的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下,就跟隨百分網小編一起去了解下吧,想了解更多相關信息請持續關注我們應屆畢業生考試網!

              PHP判斷是否為Ajax請求

              我們知道,在發送ajax請求的時候,可以通過XMLHttpRequest這個對象,創建自定義的header頭信息, 在jquery框架中,對于通過它的$.ajax, $.get, 或者$.post方法請求網頁內容時,它會向服務器傳遞一個HTTP_X_REQUESTED_WITH的參數,php中就是在header一層判斷是否是ajax請求,對應的根據$_SERVER['HTTP_X_REQUESTED_WITH']判斷。一般情況下$_SERVER['HTTP_X_REQUESTED_WITH']默認是XMLHttpRequest,$_SERVER['HTTP_X_REQUESTED_WITH']也可以自定義創建的,使用XMLHttpRequest.setRequestHeader(name,value)。

              示例:前端頁面發送普通的ajax請求給后端test.php。

              ?

              1

              2

              3

              4

              5

              6

              7

              $.ajax({

              type: "GET",

              url: 'test.php',

              success: function(data) {

              console.log(data);

              }

              });

              服務端test.php可以判斷該請求是不是Ajax異步請求,然后根據業務需求做出響應的回應。

              以下是服務端test.php的簡單驗證是否為ajax請求的代碼:

              ?

              1

              2

              3

              4

              5

              6

              7

              8

              function isAjax() {

              return @$_SERVER['HTTP_X_REQUESTED_WITH'] == 'XMLHttpRequest' ? true : false;

              }

              if (isAjax()) {

              echo 'Ajax Request Success.';

              } else {

              echo 'No.';

              }

              Ajax發起JSONP跨域請求

              我們通過jQuery的JSONP方式可以實現跨域ajax請求,服務端php也需要做出相應的處理,也就是說php這邊必須和前端頁面按照一定的格式請求和返回數據。

              示例:前端頁面發起JSONP請求:

              ?

              1

              2

              3

              4

              5

              6

              7

              8

              9

              10

              11

              12

              13

              $.ajax({

              type: "get",

              data: "random="+Math.random(),

              url: "http://demo.jb51.net/phpajax/jsonp.php",

              dataType: "jsonp",

              jsonp: "callback",

              success: function(data) {

              console.log(data);

              },

              error: function() {

              console.log('Request Error.');

              }

              });

              我們會發現,ajax請求參數中有 dataType: "jsonp" 和 jsonp: "callback" ,這個就表明了我要請求的是jsonp,并且會有回調callback返回。當然,我們也可以自定義回調函數,如 jsonpCallback:"success_jsonpCallback"

              還可以簡單的寫成:

              ?

              1

              2

              3

              4

              5

              jQuery.getJSON('http://demo.jb51.net/phpajax/jsonp.php?callback=?",{

              random: Math.random()

              }, function(data){

              console.log(data);

              });

              php后端服務代碼可以這樣寫(注意輸出返回的格式):

              ?

              1

              2

              3

              4

              5

              $data = array(

              'rand' => $_GET['random'],

              'msg' => 'Success'

              );

              echo $_GET['callback'].'('.json_encode($data).')';

              Ajax跨域請求:CORS

              CORS,又稱跨域資源共享,英文全稱Cross-Origin Resource Sharing。假設我們想使用Ajax從a.com的頁面上向b.com的頁面上要點數據,通常情況由于同源策略,這種請求是不允許的,瀏覽器也會返回“源不匹配”的錯誤,所以就有了“跨域”這個說法。但是我們也有解決辦法,我們可以再b.com的頁面header信息中增加一行代碼:

              ?

              1

              header("Access-Control-Allow-Origin: *");

              當我們設置的header為以上信息時,任意一個請求過來之后服務端我們都可以進行處理和響應,那么在調試工具中可以看到其頭信息設置,其中見紅框中有一項信息是“*Access-Control-Allow-Origin:* ”,表示我們已經啟用CORS,如果要限制只允許某個域名的請求,可以這樣:

              ?

              1

              header("Access-Control-Allow-Origin: http://www.jb51.net");

              示例:通過CORS跨域請求數據

              ?

              1

              2

              3

              4

              5

              6

              7

              8

              9

              10

              11

              12

              13

              $.ajax({

              type: "get",

              data: "random="+Math.random(),

              url: "http://demo.jb51.net/phpajax/ajax.php",

              dataType: "json",

              success: function(data) {

              console.log(data);

              $("#result_3").html(data.msg+':'+data.rand);

              },

              error: function() {

              $("#result_3").html('Request Error.');

              }

              });

              我們在另一個網站域名下的ajax.php加上這樣的代碼:

              ?

              1

              2

              3

              4

              5

              6

              header("Access-Control-Allow-Origin: http://www.jb51.net");

              $data = array(

              'rand' => $_GET['random'],

              'msg' => 'Success'

              );

              echo json_encode($data);

              這就實現了從www.jb51.net頁面發起跨域異步請求到域名路徑demo.jb51.net/phpajax/ajax.php,并得到響應。

              以上所述是小編給大家介紹的PHP處理Ajax請求與Ajax跨域,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

            【PHP處理Ajax請求與Ajax跨域問題】相關文章:

            Java Ajax jsonp跨域請求詳解05-31

            PHP中檢測ajax請求的代碼實例03-16

            PHP+Ajax+lottery.js抽獎02-25

            什么是Ajax04-26

            基于PHP+Ajax實現表單驗證的詳解05-19

            php跨域調用json的例子02-25

            php+ajax實時輸入自動搜索匹配的方法05-16

            php+ajax實現無刷新數據分頁例子07-31

            php+ajax實現無刷新的新聞留言系統01-10

                    <pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

                    <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

                    <p id="bbfd9"></p>

                    <p id="bbfd9"><cite id="bbfd9"></cite></p>

                      <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

                      <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
                      <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
                      飘沙影院