欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Node中解決接口跨域問題詳解

 更新時(shí)間:2023年04月26日 09:23:54   作者:codinglin  
在 Node 中編寫接口時(shí),我們常常會(huì)遇到跨域問題,通過本篇文章,我們來聊聊如何解決 Node 中接口的跨域問題,文中代碼示例介紹了非常詳細(xì),需要的朋友可以借鑒一下

前言

在 Node 中編寫接口時(shí),我們常常會(huì)遇到跨域問題,通過本篇文章,我們來聊聊如何解決 Node 中接口的跨域問題。

解決接口的跨域問題的常用方法有兩種:

  • CORS (主流的解決方法,推薦)

  • JSONP (有缺陷的解決方法,只支持 GET 請(qǐng)求)

下面我們重點(diǎn)來了解一下 CORS 這種跨域解決方案......

CORS

CORS (Cross-Origin Resource Sharing,跨域資源共享)由一系列 HTTP 響應(yīng)頭組成,這些 HTTP 響應(yīng)頭決定瀏覽器是否阻止前端 JS 代碼跨域獲取資源。

瀏覽器的同源安全策略默認(rèn)會(huì)阻止網(wǎng)頁跨域獲取資源。但如果接口服務(wù)器配置了 CORS 相關(guān)的 HTTP 響應(yīng)頭,則可以解除瀏覽器端的跨域訪問限制。

  • CORS 主要在 服務(wù)器端 進(jìn)行配置,客戶端瀏覽器無須做任何額外的配置,即可請(qǐng)求開啟了 CORS 的接口。

  • CORS 在瀏覽器中有兼容性。只有支持 XMLHttpRequest Level2 的瀏覽器,才能正常訪問開啟了 CORS 的服務(wù)器端口。(如:IE10+、Chrome4+、FireFox3.5+)

CORS 響應(yīng)頭部 - Access-Control-Allow-Origin

響應(yīng)頭部可以攜帶一個(gè) Access-Control-Allow-Origin 字段,其語法如下:

Access-Control-Allow-Origin: <origin> | *

其中,origin 參數(shù)的值指定了允許訪問該資源的外域 URL。例如,下面的字段值只允許來自 itcast.cn 的請(qǐng)求:

res.setHeader("Access-Control-Allow-Origin", "http://itcast.cn");

* 表示允許來自任何域的請(qǐng)求

CORS 響應(yīng)頭部 - Access-Control-Allow-Headers

默認(rèn)情況下,CORS 僅支持客戶端向服務(wù)器發(fā)送如下的 9 的請(qǐng)求頭:

Accept、Accept-Language、Content-Language、DPR、Downlink、Save-Data、Viewport-Width、Width、Content-Type(值僅限于 text/plain、multipart/form-data、application/x-www-form-urlencoded 三者之一)

如果客戶端向服務(wù)器發(fā)送了額外的請(qǐng)求頭信息,則需在服務(wù)器端通過 Access-Control-Allow-Headers 對(duì)額外的請(qǐng)求頭進(jìn)行聲明,否則這次請(qǐng)求會(huì)失敗!

// 允許客戶端額外向服務(wù)器發(fā)送 Content-Type 請(qǐng)求頭和 X-Custom-Header 請(qǐng)求頭
res.setHeader("Access-Control-Allow-Headers", "Content-Type, X-Custom-Header");

CORS 響應(yīng)頭部 - Access-Control-Allow-Methods

默認(rèn)情況下,CORS 僅支持客戶端發(fā)起 GET、POST、HEAD 請(qǐng)求。如果客戶端希望通過 PUT、DELETE 等方式請(qǐng)求服務(wù)器的資源,則需要在服務(wù)器端,通過 Access-Control-Allow-Methods 來指明實(shí)際請(qǐng)求所允許使用的 HTTP 方法。

res.setHeader("Access-Control-Allow-Methods", "POST,GET,DELETE,HEAD");
// 允許使用所有的 HTTP 請(qǐng)求方法
res.setHeader("Access-Control-Allow-Methods", "*");

CORS 請(qǐng)求的分類

客戶端在請(qǐng)求 CORS 接口時(shí),根據(jù)請(qǐng)求方式和請(qǐng)求頭不同,可以將 CORS 的請(qǐng)求分為兩大類,分別是:

  • 簡(jiǎn)單請(qǐng)求

同時(shí)滿足兩大條件的請(qǐng)求,就屬于簡(jiǎn)單請(qǐng)求:

  • 請(qǐng)求方式:GET、POST、HEAD 三者之一

  • HTTP 頭部信息無自定義的頭部字段

  • 預(yù)檢請(qǐng)求

只要符合以下任何一個(gè)條件的請(qǐng)求,都屬于預(yù)檢請(qǐng)求:

  • 請(qǐng)求方式為 GET、POST、HEAD 之外的請(qǐng)求類型

  • 請(qǐng)求頭中包含自定義頭部字段

  • 向服務(wù)器發(fā)送了 application/json 格式的數(shù)據(jù)

在瀏覽器與服務(wù)器正式通信之前,瀏覽器會(huì)先發(fā)送 OPTION 請(qǐng)求進(jìn)行預(yù)檢,以獲知服務(wù)器是否允許該實(shí)際請(qǐng)求,所以這一次的 OPTION 請(qǐng)求稱為預(yù)檢請(qǐng)求。服務(wù)器成功響應(yīng)預(yù)檢請(qǐng)求后,才會(huì)發(fā)送真正的請(qǐng)求,并且攜帶真實(shí)數(shù)據(jù)。

簡(jiǎn)單請(qǐng)求和預(yù)檢請(qǐng)求的區(qū)別

簡(jiǎn)單請(qǐng)求:客戶端和服務(wù)器之間只會(huì)發(fā)生一次請(qǐng)求。

預(yù)檢請(qǐng)求:客戶端和服務(wù)器之間會(huì)發(fā)生兩次請(qǐng)求,OPTION 預(yù)檢請(qǐng)求成功之后,才會(huì)發(fā)起真正的請(qǐng)求。

JSONP

瀏覽器通過 <script> 標(biāo)簽的 src 屬性請(qǐng)求服務(wù)器上的數(shù)據(jù),同時(shí)服務(wù)器返回一個(gè)函數(shù)的調(diào)用。這種請(qǐng)求數(shù)據(jù)的方式叫做 JSONP。

特點(diǎn):

  • JSONP 不屬于真正的 Ajax 請(qǐng)求,因?yàn)樗鼪]有使用 XMLHttpRequest 這個(gè)對(duì)象。

  • JSONP 僅支持 GET 請(qǐng)求。

如果項(xiàng)目中已經(jīng)配置了 CORS 跨域資源共享,為了防止沖突,必須在配置 CORS 中間件之前聲明 JSONP 的接口,否則 JSONP 接口會(huì)被處理成開啟了 CORS 的接口。

最后

文中主要介紹了 CORS 這種解決方案,對(duì)于 JSONP 只是進(jìn)行了簡(jiǎn)單地描述,如果覺得有不足的地方,歡迎大家在評(píng)論區(qū)補(bǔ)充~

到此這篇關(guān)于Node中解決接口跨域問題詳解的文章就介紹到這了,更多相關(guān)Node解決接口跨域內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

  • npm ci命令的基本使用方法

    npm ci命令的基本使用方法

    這篇文章主要給大家介紹了關(guān)于npm ci命令的基本使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • nodejs制作一個(gè)文檔同步工具自動(dòng)同步到gitee中的實(shí)現(xiàn)代碼

    nodejs制作一個(gè)文檔同步工具自動(dòng)同步到gitee中的實(shí)現(xiàn)代碼

    這篇文章主要介紹了nodejs制作一個(gè)文檔同步工具自動(dòng)同步到gitee中,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • NodeJS中的命令行程序、工程目錄、NPM

    NodeJS中的命令行程序、工程目錄、NPM

    使用NodeJS編寫的東西,要么是一個(gè)包,要么是一個(gè)命令行程序,而前者最終也會(huì)用于開發(fā)后者,一般我們會(huì)同時(shí)提供命令行模式和API模式兩種使用方式,并且我們會(huì)借助三方包來編寫代碼,NPM是隨同NodeJS一起安裝的包管理工具,能解決NodeJS代碼部署上的很多問題
    2023-11-11
  • nodejs搭建本地http服務(wù)器教程

    nodejs搭建本地http服務(wù)器教程

    本篇文章主要介紹了nodejs搭建本地http服務(wù)器教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • 詳解如何在Node.js中執(zhí)行CPU密集型任務(wù)

    詳解如何在Node.js中執(zhí)行CPU密集型任務(wù)

    Node.js通常被認(rèn)為不適合CPU密集型應(yīng)用程序,Node.js的工作原理使其在處理I/O密集型任務(wù)時(shí)大放異彩,雖然執(zhí)行CPU密集型任務(wù)肯定不是Node的主要使用場(chǎng)景,但是我們依舊有方法來改善這些問題,本文詳細(xì)給大家介紹了如何在Node.js中執(zhí)行CPU密集型任務(wù)
    2023-12-12
  • 詳解使用PM2管理nodejs進(jìn)程

    詳解使用PM2管理nodejs進(jìn)程

    本篇文章主要介紹了詳解使用PM2管理nodejs進(jìn)程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10
  • 整理幾個(gè)關(guān)鍵節(jié)點(diǎn)深入理解nodejs

    整理幾個(gè)關(guān)鍵節(jié)點(diǎn)深入理解nodejs

    這篇文章主要介紹了整理幾個(gè)關(guān)鍵節(jié)點(diǎn)深入理解nodejs,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,需要的小伙伴可以參考一下,需要的小伙伴可以參考一下
    2022-07-07
  • Express的HTTP重定向到HTTPS的方法

    Express的HTTP重定向到HTTPS的方法

    本篇文章主要介紹了Express的HTTP重定向到HTTPS的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • 基于Koa2寫個(gè)腳手架模擬接口服務(wù)的方法

    基于Koa2寫個(gè)腳手架模擬接口服務(wù)的方法

    這篇文章主要介紹了基于Koa2寫個(gè)腳手架模擬接口服務(wù)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • 最新評(píng)論