摘要:于是,不法分子們就抓住這個漏洞,開始了與瀏覽器的同源策略做斗爭,打了場勝仗。于是呢,所謂的就相當(dāng)于是利用到的這一段代碼的方式。使用方法就是前后端相互溝通好,前端定義好一個函數(shù),用來解析異步請求的數(shù)據(jù)。
為什么要寫這個短文?我在復(fù)習(xí) JSONP 知識的時候,隨便搜了幾篇文章看,額......后來就有了寫它的想法。
首先,頁面中的標(biāo)簽里面放的是 js 代碼,而加上 src 屬性后標(biāo)簽就有了加載和運(yùn)行外部 js 代碼的能力。
于是,不法分子們就抓住這個漏洞,開始了與瀏覽器的同源策略做斗爭,打了場勝仗。
加上 src 屬性的 script 標(biāo)簽,是利用 HTTP 的 GET 方法去訪問你指定的 url 的,
它預(yù)期會 GET 到一個 js 文件或者是一段 js 代碼,然后瀏覽器會去執(zhí)行它。
于是呢,所謂的 JSONP 就相當(dāng)于是利用 GET 到的這一段 js 代碼的方式。
使用方法就是:
1、前后端相互溝通好,前端定義好一個函數(shù),用來解析異步請求的數(shù)據(jù)。
例子:
function ajax(result) { // 處理 result }
2、后端寫一個接口,告訴前端你請求我接口的時候要加上 function 這個參數(shù),然后返回這個函數(shù)的執(zhí)行方式。
例子:
// 接口:http://www.abc.com/api?function=ajax // 后端得到 function 參數(shù)的這個前端定義的函數(shù)名,示例是 ajax,然后像下面這樣組合好后返回: // return "ajax(1)";
3、前端在 script 標(biāo)簽里的 src 屬性設(shè)置為這個接口。
例子:
這個時候,瀏覽器就會去 GET 請求接口,然后 script 標(biāo)簽得到 ajax(1) 這個 js 代碼,然后瀏覽器開始執(zhí)行它,因?yàn)槟闶孪纫呀?jīng)定義過 ajax 函數(shù)了,所以 ajax(1) 會正常運(yùn)行。
但是,第三步需要是異步請求,那么就在需要做請求操作的地方,利用 js 生成這段 script 標(biāo)簽放到
里面就行了(或者是把 src 用js動態(tài)改一下,這個我倒是沒有試過)。這就是 JSONP 啦。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/101396.html
摘要:前言之前投遞了騰訊的實(shí)習(xí)生前端崗,一直沒有電話,查了下狀態(tài)說不合適,以為涼涼了,今天卻收到了電話,出乎意料然后就開始了一面,一開始面試官說時間不會太久,大概分鐘吧,結(jié)果整個過程也就持續(xù)了分鐘吧。 前言 之前投遞了騰訊的實(shí)習(xí)生前端崗,一直沒有電話,查了下狀態(tài)說不合適,以為涼涼了,今天卻收到了電話,出乎意料...然后就開始了一面,一開始面試官說時間不會太久,大概30分鐘吧,結(jié)果整個過程也就...
摘要:應(yīng)用常見安全漏洞一覽注入注入就是通過給應(yīng)用接口傳入一些特殊字符,達(dá)到欺騙服務(wù)器執(zhí)行惡意的命令。此外,適當(dāng)?shù)臋?quán)限控制不曝露必要的安全信息和日志也有助于預(yù)防注入漏洞。 web 應(yīng)用常見安全漏洞一覽 1. SQL 注入 SQL 注入就是通過給 web 應(yīng)用接口傳入一些特殊字符,達(dá)到欺騙服務(wù)器執(zhí)行惡意的 SQL 命令。 SQL 注入漏洞屬于后端的范疇,但前端也可做體驗(yàn)上的優(yōu)化。 原因 當(dāng)使用外...
摘要:應(yīng)用常見安全漏洞一覽注入注入就是通過給應(yīng)用接口傳入一些特殊字符,達(dá)到欺騙服務(wù)器執(zhí)行惡意的命令。此外,適當(dāng)?shù)臋?quán)限控制不曝露必要的安全信息和日志也有助于預(yù)防注入漏洞。 web 應(yīng)用常見安全漏洞一覽 1. SQL 注入 SQL 注入就是通過給 web 應(yīng)用接口傳入一些特殊字符,達(dá)到欺騙服務(wù)器執(zhí)行惡意的 SQL 命令。 SQL 注入漏洞屬于后端的范疇,但前端也可做體驗(yàn)上的優(yōu)化。 原因 當(dāng)使用外...
現(xiàn)在流行的axios庫不支持jsonp,因此這里推薦一個jsonp庫,簡單易用。以下是介紹: Easy JSONP A minimal and lightweight JSONP implementation which is used to be a kind of cross domain solutions. Features Implement JSONP request from th...
摘要:同源策略做了很嚴(yán)格的限制,但是在實(shí)際的場景中,又確實(shí)有很多地方需要突破同源策略的限制,也就是我們常說的跨域。使用跨域由于同源策略,一般來說位于的網(wǎng)頁無法與不是的服務(wù)器溝通,而的元素是一個例外。 本菜雞最近在寫某個頁面請求數(shù)據(jù)時,報(bào)了如下的錯誤。 Failed to load https://...:No Access-Control-Allow-Origin header is pre...
閱讀 2999·2021-10-27 14:16
閱讀 706·2021-10-13 09:39
閱讀 3716·2021-09-29 09:46
閱讀 2101·2019-08-30 15:54
閱讀 2607·2019-08-30 15:52
閱讀 3005·2019-08-30 15:44
閱讀 1115·2019-08-30 15:44
閱讀 507·2019-08-30 10:51