什么是jsonp

什么是jsonp,jsonp是什么,jsonp如何使用

首先先知道

  1. jsonp的核心原理就是目標頁面回調本地頁面的方法,并帶入參數
  2. 我們常用的動態頁面有jsp,php,aspx

為什么需要JSONP?

由于瀏覽器安全限制,數據是不可以直接跨域(包括不同的根域名、二級域名、或不同的端口)請求的,除非目標域名授權你可以訪問。比如設置crossdomain.xml 或在http頭部里授權

但是crossdomain.xml會允許設置的網站訪問所有的數據,而頭部設置又非常麻煩。

所以可以在你授權的數據返回里設置jsonp來讓該接口允許所有的調用者獲取數據。

JSONP的原理

jsonp是使用方法回調的原理.

在網頁里,你如果引入其他網頁的js,那這個頁面的js是可以調用你網頁的代碼的

直接請求js 和 請求的動態頁面(jsp,php,aspx)里輸出的javascript代碼 效果一樣

function showjson(json){
	alert(json.url);
}
如果引用的js或動態頁面里有 showjson({"url":"http://www.dg112.com"});這行代碼的話,那就會彈出 http://www.dg112.com

jsonp的第一種方式,將目標作為js形式加載過來,盡管其實對方是一個php

下面我們在這個頁面里來請求頁面的數據,這個php頁面數據會有回調函數showjson,來調用我們這個bejson頁面里的 showjson方法 并將一個json傳入
< ?php 
	//這里是php頁面里,回調showjson方法,這里的方法必須和上面定義的本地頁面中的回調方法一致
	echo 'showjson({"url":"http://www.dg112.com"})';
?>
	
$("#getuserp").click(function(){
	$.getScript("http://www.dg112.com/");
});
	

那如果我們抓包后就會看到(如上圖),點擊按鈕后發起了一個http請求,

請求了//www.dg112.com/頁面,

頁面里輸出了 showjson({"url":"http://www.dg112.com"}) ,

因為是以javascript文件形式加載過來 ,所以他會對本地頁面showjson發起回調(看綠色箭頭),并傳入json參數(看紅色箭頭),所以就會彈出了json中的url

直接用jquery的ajax來請求jsonp

 $.ajax({
     url:'//www.dg112.com/',
     dataType:"jsonp",
     jsonp:"showjson", //這里的參數必須和目標頁面里的回調函數一樣
     success:function(data){
        alert(data.url);
     }
});			
		

国产剧情在线播放| 免费A级毛片高清在钱| a破外女出血毛片| 成人欧美一区二区三区黑人| 亚洲中文字幕无码日韩| 欧美精品亚洲精品日韩专区| 免费视频爱爱太爽了| 精品国产欧美一区二区| 国产99视频精品免费视频7| 精品国产福利第一区二区三区| 喝茶影视喝茶影院最新电影电视剧| 视频一区二区在线观看| 国产六月婷婷爱在线观看| 美国一级片免费| 国产在线观看色| 老熟妇高潮一区二区三区| 国产婷婷一区二区三区| 被黑化男配做到哭h| 国产乱码精品一区二区三区中文| 马浩宁高考考了多少分| 国产在视频线精品视频| 美女被羞羞在线观看漫画| 国产成人免费高清激情视频| 2022久久国产精品免费热麻豆 | 国产强伦姧在线观看| 萝li交小说合集| 国产特级毛片aaaaaa高潮流水 | 一区二区三区中文字幕| 成人亚洲国产精品久久| 久久久无码精品亚洲日韩蜜桃| 日本理论片午夜论片| 亚洲一区中文字幕在线电影网| 最近中文2019字幕第二页| 亚洲国产AV一区二区三区四区| 日韩成人在线网站| 亚洲AV日韩AV永久无码下载| 日本爽爽爽爽爽爽在线观看免| 丹麦大白屁股hdxxxx| 成人网免费观看| 一级黄色毛片免费看| 少妇人妻偷人精品一区二区|