W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
IncomingRequest::isAJAX()
方法使用了 X-Requested-With
請(qǐng)求頭來(lái)確定一個(gè)請(qǐng)求是否是XHR(XML Http Request)或者是一個(gè)正常的請(qǐng)求。 然后最新的JavaScript實(shí)現(xiàn)(例如fetch方法)中不再隨著請(qǐng)求發(fā)送這個(gè)頭,因此使用 IncomingRequest::isAJAX()
就不那么可靠了,因?yàn)闆](méi)有這個(gè)頭,該方法就不能識(shí)別一個(gè)請(qǐng)求是否是一個(gè)XHR。
為了解決這個(gè)問(wèn)題,最有效的解決方式(至今)就是人為定義一個(gè)請(qǐng)求頭,迫使這個(gè)請(qǐng)求信息發(fā)送的服務(wù)器從而識(shí)別這個(gè)請(qǐng)求是否是一個(gè)XHR。
以下就是如何迫使在Fetch API和其他JavaScript庫(kù)中發(fā)送 X-Requested-With
請(qǐng)求頭。
fetch(url, {
method: "get",
headers: {
"Content-Type": "application/json",
"X-Requested-With": "XMLHttpRequest"
}
});
對(duì)于類(lèi)似jQuery之類(lèi)的庫(kù)來(lái)說(shuō),不需要額外發(fā)送這個(gè)頭,因?yàn)楦鶕?jù) 官方文檔 ,對(duì)于所有 $.ajax()
請(qǐng)求來(lái)說(shuō),這都是一個(gè)標(biāo)準(zhǔn)頭。 但是如果你還是不想擔(dān)風(fēng)險(xiǎn)并強(qiáng)制發(fā)送這個(gè)頭,就像下面這樣做吧:
$.ajax({
url: "your url",
headers: {'X-Requested-With': 'XMLHttpRequest'}
});
在VueJS中你只需要在 created
函數(shù)中增加以下代碼,只要你在這類(lèi)請(qǐng)求時(shí)使用Axios:
axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest';
axios.get("your url", {headers: {'Content-Type': 'application/json'}})
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: