摘要:說明關(guān)于跨域問題的解決方案多達(dá)七八種,你不要說哪有這么多,我不跟你較真哈,你也別跟我較真哈自行百度或這里不會(huì)跟你說那么多種只說使用最多的一種你要非說用的不是最多的我不信哦你信好了哈哈你開心就好關(guān)于跨域?yàn)g覽器的同源策略要了解什么是跨域你需要了
說明
關(guān)于跨域問題的解決方案多達(dá)七、八種,你不要說哪有這么多,我不跟你較真哈,你也別跟我較真哈, ?!自行 百度 或 Google, 這里不會(huì)跟你說那么多種, 只說使用最多的一種 JSONP, 你要非說 JSONP 用的不是最多的, 我不信哦, 你信好了, 哈哈, 你開心就好?關(guān)于跨域
瀏覽器的同源策略
要了解什么是 跨域 你需要了解什么是瀏覽器的 同源策略
瀏覽器允許訪問的資源必要條件
其實(shí)說白了就一句話 相同域名、相同協(xié)議、相同端口 瀏覽器才允許訪問, 這是出于安全方面的考慮, 其它一律不允許訪問!
瀏覽器允許訪問的同源資源俗解
比如說: a.com/article/mid/512 要訪問 a.com/data/detail/512 是允許訪問的, a.com/article/mid/512 要訪問 b.com/data/detail/512 是拒絕的!
A域名下訪問B域名資源
那么非要訪問不同域名下的資源, 怎么辦呢?那么問題來了!跨域不使用跨域訪問
這種方式是在沒有跨域訪問其它域名資源URL常規(guī)做法!而訪問其它域名資源URL是不可行的!前端代碼
瀏覽器開發(fā)者工具控制臺(tái)提示JSONP TEST
可以發(fā)現(xiàn)控制臺(tái)并沒有輸出任何返回?cái)?shù)據(jù), 因?yàn)樗矝]有數(shù)據(jù)可輸出, 而是給出了下面這樣一個(gè)提示信息:瀏覽器開發(fā)者工具網(wǎng)絡(luò)請求列表詳情
而在網(wǎng)絡(luò)請求列表可以看到請求資源URL沒有返回任何數(shù)據(jù)后端返回?cái)?shù)據(jù)形式
既然通過 jQuery 的 AJAX 方法返回?cái)?shù)據(jù)形式是 JSON 格式, 請求資源URL, 沒有獲取到任何數(shù)據(jù), 通過瀏覽器直接訪問資源URL可以正常獲取到數(shù)據(jù)!使用JSONP跨域訪問資源 前端或客戶端處理
從上面可以看到通過瀏覽器直接訪問資源URL也就是API接口是可以獲取到數(shù)據(jù)的, 而通過返回?cái)?shù)據(jù)形式為 JSON 的方式是拒絕訪問的, 那么要想通過在 tem.mac.dev 這個(gè)域名訪問 warnerwu.centos.dev 域名下的API接口URL資源就需要使用 JSONP, 只需要將 jQuery 中 AJAX 方法中的 dataType 值修改為即可
dataType : "JSONP"
注意
這里也只是限于把上面所說的「直接通過瀏覽器訪問資源API接口URL獲取到的數(shù)據(jù)」通過JSONP的形式給獲取到了而已也只是僅僅如此, 下面再次刷新頁面通過 JSONP 訪問資源API接口URL來驗(yàn)證這一點(diǎn)!
在控制臺(tái)下已經(jīng)看不到 已攔截跨域請求 的警告信息啦!而是 空空如也 哦 ?
那既然在 控制臺(tái) 看不到任何 警告 信息也看不到數(shù)據(jù)輸出, 不防看一下 網(wǎng)絡(luò) 請求列表是怎么樣的!
從 網(wǎng)絡(luò) 請求列表中的最后一條可以看出這個(gè)訪問資源API接口的完整URL是:
http://warnerwu.centos.dev/?c=adCreativeLib&a=api&type=list&callback=jQuery21408945840059161158_1519958486174&_=1519958486175
這里你就會(huì)發(fā)現(xiàn)這個(gè)請求資源地址與 AJAX 方法中的 url 參數(shù)值截然不同! 它多了兩個(gè)參數(shù):
callback=jQuery21408945840059161158_1519958486174&_=1519958486175
是這樣的, 在使用 jQuery 的 AJAX 方法時(shí), 如果指定返回?cái)?shù)據(jù)方式是 JSONP 時(shí), 也就是 AJAX 參數(shù)對象字面量 dataType : "JSONP" 時(shí), 如下所示:
$.ajax({ type : "GET", dataType : "JSONP", url : "http://warnerwu.centos.dev/?c=adCreativeLib&a=api&type=list", success : function (data){ console.log(data); } });
它就會(huì)在發(fā)起請求資源時(shí)在 AJAX 方法參數(shù)對象字面量 url 的具體鏈接上自動(dòng)添加參數(shù) callback 和 _, 而且這兩個(gè)參數(shù)的值基本上永遠(yuǎn)不會(huì)重復(fù)
callback: 值為隨機(jī)以 jQuery 開頭后跟隨機(jī)數(shù)字字符串的回調(diào)函數(shù)名稱
_: 值為隨機(jī)數(shù)字字符串, 它保證每次發(fā)起 AJAX 請求都是新的, 而不會(huì)使用瀏覽器已請求過的URL 緩存機(jī)制 已存在資源
在上圖中可以看到 網(wǎng)絡(luò) 請求資源列表中API接口訪問URL的具體參數(shù)列表, 而 響應(yīng) 具體是這樣的:
可以看到 響應(yīng) 返回的是JSON格式的數(shù)據(jù), 這樣是不對的!不防再看一下 控制臺(tái):
可以看到控制臺(tái)依然是 空空如也!什么都沒有, 到目錄為止其實(shí) 前端或客戶端 所做的工作已經(jīng)完成!接下來就是 服務(wù)器端 API接口要做些修改操作嘍!服務(wù)器端處理
這里使用的服務(wù)器端語言是 PHP, 其它語言也是一樣處理哦!
其實(shí)服務(wù)器端所以要的調(diào)整很簡單, 只需要獲取請求參數(shù) callback, 然后返回以 callback 參數(shù)值為函數(shù)名稱的JSONP格式的編碼數(shù)據(jù)字符串即可
這種處理方式是針對不存在跨域API接口請求獲取數(shù)據(jù)時(shí)通常的做法, 如果是JSONP跨域請求API接口獲取數(shù)據(jù)時(shí)就不通用嘍!
可以看到這里在服務(wù)器端處理為通用請求獲取數(shù)據(jù)返回形式, 不管是否是跨域請求API接口均可使用!
你會(huì)發(fā)現(xiàn)請求API接口數(shù)據(jù)成功, 并且請求時(shí)的 callback 參數(shù)值和返回的JSONP格式數(shù)據(jù)方法名稱一致, 獲取到的JSONP格式數(shù)據(jù)怎么處理的呢?當(dāng)請求成功時(shí)就會(huì)執(zhí)行以 jQuery 下 AJAX 方法生成的 callback 參數(shù)值對就的函數(shù), 恰好這個(gè)正是從服務(wù)器端返回的JSONP格式數(shù)據(jù), 函數(shù)執(zhí)行結(jié)束后返回主題數(shù)據(jù)也就是與服務(wù)器端編碼返回之前的數(shù)據(jù)類型一致的數(shù)據(jù)形式
以上是跨域請求API接口通過控制臺(tái)輸出的數(shù)組數(shù)據(jù)
以上是通過瀏覽器直接訪問API接口獲取的數(shù)組數(shù)據(jù)總結(jié)
說白了使用 JQuery 的 AJAX 方法實(shí)現(xiàn)跨域請求資源是非常簡單的!前端代碼
$.ajax({ type : "GET", dataType : "JSONP", url : "http://warnerwu.centos.dev/?c=adCreativeLib&a=api&type=list", success : function (data){ console.log(data); } });服務(wù)器端代碼
其實(shí)非常簡單的問題在這里說了這么多, 大家見諒!?以上就是 JSONP跨域訪問API接口深入理解 的詳細(xì)過程, 謝謝您的支持!
希望本文對你的工作和學(xué)習(xí)有所幫助
如果覺得還不錯(cuò)并且也長知識了, 怎么感謝我呢? 媽呀! 點(diǎn)贊啊!
Good Luck! from warnerwu at 2018.03.02 PM, email address is warnerwu@126.com
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/28313.html
摘要:,跨站腳本攻擊。實(shí)際發(fā)的請求就是,用于表示這是一個(gè)請求。,用于告知服務(wù)器根據(jù)這個(gè)參數(shù)獲取回調(diào)函數(shù)的名稱,通常約定就叫。,回調(diào)函數(shù)的名稱,也是前面參數(shù)的值,可省略,會(huì)自動(dòng)生成。 本次課程主要圍繞 PHP 面試和筆試中經(jīng)常會(huì)出現(xiàn)的一些知識點(diǎn),但是面試官會(huì)在筆試題基礎(chǔ)上深入擴(kuò)展,那么你知道如何更好的回答讓面試官滿意嗎?題目收集自騰訊,迅雷,美圖等公司的筆試面試題,以及本人面試經(jīng)歷中印象中的知...
摘要:實(shí)現(xiàn)跨域請求的原理簡單的說,就是動(dòng)態(tài)創(chuàng)建標(biāo)簽,然后利用的不受同源策略約束來跨域獲取數(shù)據(jù)。回調(diào)函數(shù)的名字一般是在請求中指定的。 怎么處理跨域問題呢?相信在看了這篇文章,您就理解了什么是跨域,怎么處理跨域問題了。 一、同源策略 要理解跨域,先要了解一下同源策略。所謂同源是指,域名,協(xié)議,端口相同。所謂同源策略,簡單的說就是基于安全考慮,當(dāng)前域不能訪問其他域的東西。 在同源策略下,在某個(gè)服務(wù)...
摘要:跨域訪問的處理辦法及適用條件適用條件請求的接口需要支持訪問這里需要強(qiáng)調(diào)的是,不屬于的部分,它只是把放入標(biāo)簽中實(shí)現(xiàn)的數(shù)據(jù)傳輸,不受同源策略限制。 為什么會(huì)有跨域問題 我們試想一下以下幾種情況: 我們打開了一個(gè)天貓并且登錄了自己的賬號,這時(shí)我們再打開一個(gè)天貓的商品,我們不需要再進(jìn)行一次登錄就可以直接購買商品,因?yàn)檫@兩個(gè)網(wǎng)頁是同源的,可以共享登錄相關(guān)的 cookie 或 localStor...
閱讀 1979·2021-11-22 15:33
閱讀 3011·2021-11-18 10:02
閱讀 2622·2021-11-08 13:16
閱讀 1634·2021-10-09 09:57
閱讀 1378·2021-09-30 09:47
閱讀 2013·2019-08-29 13:05
閱讀 3079·2019-08-29 12:46
閱讀 1016·2019-08-29 12:19