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

options預檢請求的前后端解決方式詳解

 更新時間:2023年04月24日 14:31:19   作者:地霊殿__三無  
這篇文章主要為大家介紹了options預檢請求的前后端解決方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

一、前言

最近在試玩openai,發(fā)送請求的時候,總是會看見一個options請求,這請求有什么意義或者作用,為什么每次調用openai的api總是會先發(fā)起option請求呢?

好奇心驅使著我去探索它,揭開它的神秘面紗。

二、請求的分類

這件事還要從瀏覽器說起,基本上我們的請求都是CORS跨域請求(前后端分離嘛,基本上部署位置的IP\端口\協(xié)議不可能完全相同,所以就屬于跨域了),CORS跨域請求需要瀏覽器和服務器同時支持。目前,所有瀏覽器都支持該功能,IE瀏覽器不能低于IE10。

而CORS跨域請求,又分成簡單請求simple request, 和復雜請求not-so-simple request。

復雜請求就會觸發(fā)我們的options預檢請求,這是符合以下規(guī)范的。

跨域共享標準規(guī)范要求,對那些可能對服務器數據產生副作用的 HTTP 請求方法
(特別是 GET 以外的 HTTP 請求,或者搭配某些 MIME 類型的 POST 請求),
瀏覽器必須首先使用 OPTIONS 方法發(fā)起一個預檢請求(preflight request),
從而獲知服務端是否允許該跨域請求。服務器確認允許之后,才發(fā)起實際的 HTTP 請求。

1、簡單請求的定義

(1)請求方式為`GET、HEAD、POST`時的請求;
(2)認為設置規(guī)范集合之內的首部字段,
    如`
    Accept/
    Accept-Language/
    Content-Language/
    Content-Type/
    DPR/
    Downlink/
    Save-Data/
    Viewport-Width/
    Width`;
(3)Content-Type 的值僅限于下列三者之一,即`
    application/x-www-form-urlencoded、
    multipart/form-data、
    text/plain`;
(4)請求中的任意 `XMLHttpRequestUpload`對象均沒有注冊任何事件監(jiān)聽器;
(5)請求中沒有使用 `ReadableStream`對象。

2、復雜請求的定義

除了上面的以外的請求,基本上都是復雜請求。

比如自定義的token、Authorization等請求頭字段,或者是PUT、DELETE等請求方式。

3、預檢帶來的小問題

因為預檢,會額外占用服務器資源,還會延遲真正請求的發(fā)起時間,導致頁面上性能變差(這一點在使用openai的api深有體會,因為是國外服務器,加上預檢,基本上每次都要返回好久)。

4、解決方式

解決方式可以從前端或者后端入手,選其一就可以了,除了以下方法,可能還有其他的解決方式。

(1)前端的解決方式

// 引入
import qs from 'qs'
// 然后在請求攔截器的部分
axios.interceptors.request.use((config) => {
  if(config.method  === 'post'){
    config.data = qs.stringify(config.data);
  }
  return config;
},(error) =>{
  return Promise.reject(error);
});

如下,從json格式變成了string字符串,后端獲取后需要重新格式化一下才能用。

 // qs.stringify 前
 config.data = {
     "userId": "520b0ec3229",
     "startTime": "15489504",
     "endTime": "1559999"
 }
 // qs.stringify 后,內容變?yōu)?
 "userId=520b0ec3229&startTime=15489504&endTime=1559999"

(2)后端的解決方式一

服務器端設置 Access-Control-Max-Age 字段,瀏覽器會根據返回的

Access-Control-Max-Age 字段緩存該請求的 OPTIONS 預檢請求的響應結果。

設置大點就可以了

比如設置30天,那就觸發(fā)一次預檢后,后續(xù)30天內,同一請求源頭不會再次觸發(fā)預檢請求。

// 后端設置,2592000單位秒,這里是30天
response.addHeader( "Access-Control-Max-Age", "2592000" )

(3) 后端解決方式二

access-control-allow-origin: *;

這種比較危險,因為允許了所有網站都可以跨域共享資源。

可以把*改為具體的網址源,也就是白名單。

以上就是options預檢請求的詳細內容,更多關于options預檢請求的資料請關注腳本之家其它相關文章!

相關文章

  • js比較兩個單獨的數組或對象是否相等的實例代碼

    js比較兩個單獨的數組或對象是否相等的實例代碼

    本文通過實例代碼給大家介紹了js比較兩個單獨的數組或對象是否相等 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • javascript彈出層輸入框(示例代碼)

    javascript彈出層輸入框(示例代碼)

    這篇文章主要介紹了javascript彈出層輸入框(示例代碼)。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • 微信小程序支付前端源碼

    微信小程序支付前端源碼

    這篇文章主要為大家詳細介紹了微信小程序支付前端源碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • 淺談js里面的InttoStr和StrtoInt

    淺談js里面的InttoStr和StrtoInt

    下面小編就為大家?guī)硪黄獪\談js里面的InttoStr和StrtoInt。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • JavaScript Date對象詳解及時間戳和時間的相互轉換問題

    JavaScript Date對象詳解及時間戳和時間的相互轉換問題

    這篇文章主要介紹了JavaScript Date對象詳解及時間戳和時間的相互轉換問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • JavaScript將坐標字符串轉為數組的項目實踐

    JavaScript將坐標字符串轉為數組的項目實踐

    本文主要介紹了JavaScript將坐標字符串轉為數組的項目實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-01-01
  • 基于javascript實現(xiàn)listbox左右移動

    基于javascript實現(xiàn)listbox左右移動

    這篇文章主要介紹了基于javascript實現(xiàn)listbox左右移動的相關資料,以一個完整的實例代碼分析了js實現(xiàn)listbox左右移動的相關技巧,感興趣的小伙伴們可以參考一下
    2016-01-01
  • JavaScript實現(xiàn)隨機點名器實例詳解

    JavaScript實現(xiàn)隨機點名器實例詳解

    這篇文章主要介紹了JavaScript隨機點名器,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • TypeScript中import?type與import的區(qū)別詳析

    TypeScript中import?type與import的區(qū)別詳析

    ES6引入了模塊化,其設計思想是在編譯時就能確定模塊的依賴關系,以及輸入和輸出的變量,下面這篇文章主要給大家介紹了關于TypeScript中import?type與import區(qū)別的相關資料,需要的朋友可以參考下
    2022-07-07
  • js中for in語句的用法講解

    js中for in語句的用法講解

    這篇文章主要介紹了js中for in語句的用法講解,本文用多個實例講解了for in語句的用法及適合場景,需要的朋友可以參考下
    2015-04-04

最新評論