首頁  >  文章  >  web前端  >  jsonp如何進行跨域獲取資料? (程式碼範例)

jsonp如何進行跨域獲取資料? (程式碼範例)

青灯夜游
青灯夜游轉載
2019-01-05 10:24:143220瀏覽

jsonp如何進行跨域獲取資料?這篇文章就跟大家介紹jsonp進行跨域取得數據的方法,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

jsonp跨域獲取資料小解

#由於瀏覽器有同源策略,所以要想取得非同源(協議,域名,連接埠三者有一不同都算非同源)的頁面的數據,就得進行跨域

(1) jsonp原理

由於script標籤的src屬性可以存取非同源的js腳本,所以透過src屬性存取伺服器會返回函數的js程式碼,而我們想要的資料就作為函數參數返回,而我們會先定義這個函數,返回的js程式碼就可執行

(2) jsonp實作程式碼

請求頁面

76c82f278ac045591c9159d381de2c57
100db36a723c770d327fc0aef2ce13b1
93f0f5c25f18dab9d176bd4f6de5d30e
    b2386ffb911b14667cb8f0f91ea547a76e916e0f7d1e588d4f442bf645aedb2f
9c3bca370b5104690d9ef395f2c5f8d1
6c04bd5ca3fcae76e30b72ad730ca86d
8019067d09615e43c7904885b5246f0a
    function jsonp(data){
        console.log(username)
    }
2cacc6d41bbb37262a98f745aa00fbf0
32c428c1a65afb4c21320ec475b9ffe4
2cacc6d41bbb37262a98f745aa00fbf0
8019067d09615e43c7904885b5246f0a
    $(document).ready(function(){
        var url = "http://www.example.com/jsonp.php?callback=jsonp";
        var script = $('3f1c4e4b6b16bbbd69b2ee476dc4f83a053a9cc4c2e9b9f6f911642332d34e85');
        script.attr("src",url);
        $("body").append(script);
    });
2cacc6d41bbb37262a98f745aa00fbf0
36cc49f0c466276486e50c850b7e4956
73a6ac4ed44ffec12cee46588e518a5e
7bf6f68ac33b2a6d14a606479bed8015

之後php會回傳

jsonp({
    name:'niuni
})

然後PHP回傳的程式碼h會被要求頁面的jsonp方法執行

#(3)jQuery的簡單jsonp跨網域

#
<script>
    function showData (data) {
        console.info(data);
    }
    $(document).ready(function () {
        $("#btn").click(function () {
            $.ajax({
                url: "http://www.example.comjsonp",
                type: "GET",
                dataType: "jsonp",// 返回数据类型
                jsonpCallback: "showData",//回调函数
                // 获取数据成功就执行success函数
                success: function (data) {
                    console.info("data");
                }
            });
        });
    });
</script>

總結:以上就是這篇文章的全部內容,希望能對大家的學習有所幫助。更多精彩內容大家可以追蹤php中文網相關教學欄位! ! !

以上是jsonp如何進行跨域獲取資料? (程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:cnblogs.com。如有侵權,請聯絡admin@php.cn刪除