前端面試題16(跨域問題)

在這里插入圖片描述
跨域問題源于瀏覽器的同源策略(Same-origin policy),這一策略限制了來自不同源的“寫”操作(比如更新、刪除數據等),同時也限制了讀操作。當一個網頁嘗試請求與自身來源不同的資源時,瀏覽器會阻止這種行為,以防止惡意網站讀取另一個網站的數據。

解決前端跨域問題有多種方法,下面詳細介紹幾種常見的解決方案:

1. JSONP (JSON with Padding)

適用場景: 主要用于GET請求,且服務器支持JSONP響應。

原理: 利用<script>標簽沒有跨域限制的特點,網頁可以加載來自不同源的JavaScript文件。服務器返回的不是JSON格式的數據,而是一個函數調用,這個函數的名字由請求時傳遞的參數指定。

示例代碼:

  • 前端:
<script>function handleResponse(data) {console.log(data);}
</script>
<script src="http://example.com/data?callback=handleResponse"></script>
  • 后端 (假設使用Node.js和Express):
app.get('/data', function(req, res) {const data = { "key": "value" };const callback = req.query.callback;res.send(`${callback}(${JSON.stringify(data)})`);
});

2. CORS (Cross-Origin Resource Sharing)

適用場景: 現代Web應用廣泛采用,支持各種HTTP方法。

原理: 通過在服務器端設置Access-Control-Allow-Origin響應頭來允許特定源或者所有源訪問資源。

服務器端設置示例 (假設使用Node.js和Express):

app.use(function(req, res, next) {res.header("Access-Control-Allow-Origin", "*");res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");next();
});

3. 使用代理服務器

適用場景: 開發環境中,尤其是前后端分離開發時。

原理: 設置一個代理服務器,前端的所有API請求都發送到這個代理,然后由代理轉發到實際的API服務器,這樣對于瀏覽器來說,請求都來自于同一個源。

配置示例 (使用Vue CLI的webpack配置):

// vue.config.js
module.exports = {devServer: {proxy: {'/api': {target: 'http://backend.example.com',changeOrigin: true,pathRewrite: {'^/api': ''},},},},
};

4. 使用fetchXMLHttpRequest的CORS模式

雖然這不是一個獨立的解決方案,但了解如何在JavaScript中利用CORS也很重要。默認情況下,現代瀏覽器的fetchXMLHttpRequest支持CORS,只需確保服務器正確設置了CORS頭部。

示例代碼 (使用fetch):

fetch('http://example.com/data', {mode: 'cors', // 默認就是cors,可以不寫headers: {'Accept': 'application/json'}
})
.then(response => response.json())
.then(data => console.log(data))
.catch(error => console.error('Error:', error));

以上是解決前端跨域問題的幾種常見方法,具體選擇哪種方案取決于你的應用場景和技術棧。在生產環境中,CORS是最常用且推薦的方式,因為它提供了靈活的安全控制和良好的兼容性。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/41494.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/41494.shtml
英文地址,請注明出處:http://en.pswp.cn/web/41494.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

網絡配置文件中type

在網絡配置文件中&#xff0c;type是一個參數&#xff0c;用于指定網絡接口的類型。它指定了網絡接口所使用的協議或技術。 以下是一些常見的type參數值&#xff1a; “ethernet”&#xff1a;表示以太網接口&#xff0c;用于連接以太網設備&#xff0c;如有線網卡。 “wifi”…

Python實現ABC人工蜂群優化算法優化隨機森林回歸模型(RandomForestRegressor算法)項目實戰

說明&#xff1a;這是一個機器學習實戰項目&#xff08;附帶數據代碼文檔視頻講解&#xff09;&#xff0c;如需數據代碼文檔視頻講解可以直接到文章最后獲取。 1.項目背景 人工蜂群算法(Artificial Bee Colony, ABC)是由Karaboga于2005年提出的一種新穎的基于群智能的全局優化…

PD虛擬機不能復制Mac的文件怎么回事 PD虛擬機不能復制Mac的文件怎么辦 Parallels Desktop怎么用

PD虛擬機不僅能提供跨系統協作的服務&#xff0c;還能進行虛擬機系統與原生系統間的文件共享、文本復制、文件復制等操作&#xff0c;讓系統間的資源可以科學利用。但在實際操作過程中&#xff0c;PD虛擬機不能復制Mac的文件怎么回事&#xff1f;PD虛擬機不能復制Mac的文件怎么…

linux centos7.9 安裝mysql5.7;root設置客戶端登錄、配置并發、表名大小寫敏感等

查看centos版本 cat /etc/centos-releasecentos版本為7.9 查看是否已安裝mariadb,安裝了需要先刪除 1.查看是否安裝了mariadb和mysql,安裝了需要先刪除 mariadb是mysql的一個分支,但要安裝mysql需要刪除它 執行rpm -qa|grep mariadb,查看mariadb情況 查找到有就刪除 執行…

中小學白名單編程競賽:精英競技場的深度解析

目錄 1. 引言2. 特點3. 為什么參加白名單編程競賽4. 具體競賽介紹4.1 全國中小學信息技術創新與實踐大賽(NOC大賽)4.1.1 面向對象4.1.2 考試內容4.1.3 賽事特點4.1.4 報名時間4.1.5 含金量4.1.6 優缺點4.1.7 賽事流程4.2 藍橋杯大賽4.2.1 面向對象4.2.2 考試內容4.2.3 賽事特…

Day59 動態規劃part12

LC115不同的子序列&#xff08;未掌握&#xff09; 遞推公式與LC392類似&#xff0c;但是初始化略有不同 LC392的dp數組含義為相同字符個數而本體的dp數組含義為出現的次數&#xff0c;因此dp[i][0]1 兩種情況 s[i-1]t[j-1] dp[i][j] dp[i-1][j-1]dp[i][j] dp[i-1][j] s[…

Kubernetes集群性能測試之kubemark集群搭建

Kubernetes集群性能測試之kubemark集群搭建 Kubemark是K8s官方提供的一個對K8s集群進行性能測試的工具。它可以模擬出一個K8s cluster&#xff08;Kubemark cluster&#xff09;&#xff0c;不受資源限制&#xff0c;從而能夠測試的集群規模比真實集群大的多。這個cluster中ma…

運維鍋總詳解系統啟動流程

本文詳細介紹Linux及Windows系統啟動流程&#xff0c;并分析了它們啟動流程的異同以及造成這種異同的原因。希望本文對您理解系統的基本啟動流程有所幫助&#xff01; 一、Linux系統啟動流程 Linux 系統的啟動流程可以分為幾個主要階段&#xff0c;從電源開啟到用戶登錄。每個…

Java筆試|面試 —— 對繼承性的理解

面試/筆試&#xff1a;談談對繼承性的理解>繼承性的好處&#xff1a;-減少了代碼的冗余&#xff0c;提高了復用性-提高了擴展性&#xff08;父類統一擴展、繼承后擴展&#xff09;-為多態的使用&#xff0c;提供了前提>Java中繼承的特點-局限性&#xff1a;類的單繼承性。…

有一個日期(Date)類的對象和一個時間(Time)類的對象,均已指定了內容,要求一次輸出其中的日期和時間

可以使用友元成員函數。在本例中除了介紹有關友元成員函數的簡單應用外&#xff0c;還將用到類的提前引用聲明&#xff0c;請讀者注意。編寫程序&#xff1a; 運行結果&#xff1a; 程序分析&#xff1a; 在一般情況下&#xff0c;兩個不同的類是互不相干的。display函…

關于Java異常機制及finally關鍵字的詳解

異常機制(Exception) 軟件程序在運行過程中&#xff0c;非常可能遇到異常問題。常見的異常&#xff1a; 1、用戶輸入錯誤 2、設備錯誤 3、硬件問題&#xff0c;例如打印機關掉、服務器問題 4、物理限制&#xff1a;磁盤滿了 Java是采用面向對象的方式來處理異常的。 處理過程…

基于Java的水果商品銷售網站

1 水果商品銷售網站概述 1.1 課題簡介 隨著電子商務在當今社會的迅猛發展&#xff0c;水果在線銷售已逐漸演變為一種極為便捷的購物方式&#xff0c;日益受到人們的青睞。本系統的設計初衷便是構建一個功能完備、用戶體驗友好的水果銷售平臺&#xff0c;致力于為用戶提供優質、…

Xcode簡介

Xcode 是蘋果公司為 macOS 平臺開發的一款集成開發環境&#xff08;Integrated Development Environment&#xff0c;IDE&#xff09;&#xff0c;主要用于開發 iOS、iPadOS、macOS、watchOS 和 tvOS 的應用程序。Xcode 包含了一系列的軟件開發工具&#xff0c;涵蓋了從編寫代碼…

【植物大戰僵尸雜交版】獲取+存檔插件

文章目錄 一、還記得《植物大戰僵尸》嗎&#xff1f;二、在哪下載&#xff0c;怎么安裝&#xff1f;三、雜交版如何進行存檔功能概述 一、還記得《植物大戰僵尸》嗎&#xff1f; 最近&#xff0c;一款曾經在15年前風靡一時的經典游戲《植物大戰僵尸》似乎迎來了它的"文藝復…

漸開線花鍵測量學習筆記分享

大家好&#xff0c;繼續漸開線花鍵的相關內容&#xff0c;本期是漸開線花鍵測量相關的學習筆記分享&#xff1a; 花鍵檢測項目有花鍵大徑和小徑檢驗&#xff1b;內花鍵齒槽寬和外花鍵齒厚&#xff0c;以及漸開線終止圓 和起始圓直徑檢測&#xff1b;齒距累計誤差 、齒形誤差 、…

排序算法簡述(第八jiang)

目錄 排序 選擇排序 O(n2) 不穩定&#xff1a;48429 歸并排序 O(n log n) 穩定 插入排序 O(n2) 堆排序 O(n log n) 希爾排序 O(n log2 n) 圖書館排序 O(n log n) 冒泡排序 O(n2) 優化&#xff1a; 基數排序 O(n k) 快速排序 O(n log n)【分治】 不穩定 桶排序 O(n…

Mysql-常用函數及其用法總結

1、字符串函數 測試用例如下&#xff1a; 1.1 CONCAT() 將多個字符串連接成一個字符串。 SELECT CONCAT(first_name, , last_name) AS full_name FROM users; -- 期望結果&#xff1a;John Doe, Jane Smith, Michael Johnson 1.2 SUBSTRING() 提取子字符串 SELECT SUBSTR…

STM32-PWR和WDG看門狗

本內容基于江協科技STM32視頻學習之后整理而得。 文章目錄 1. PWR1.1 PWR簡介1.2 電源框圖1.3 上電復位和掉電復位1.4 可編程電壓監測器1.5 低功耗模式1.6 模式選擇1.7 睡眠模式1.8 停止模式1.9 待機模式1.10 庫函數 2. WDG看門狗2.1 WDG簡介2.2 IWDG框圖2.3 IWDG鍵寄存器2.4 …

13 學習總結:指針 · 其一

目錄 一、內存和地址 &#xff08;一&#xff09;內存 &#xff08;二&#xff09;內存單元 &#xff08;三&#xff09;地址 &#xff08;四&#xff09;拓展&#xff1a;CPU與內存的聯系 二、指針變量和地址 &#xff08;一&#xff09;創建變量的本質 &#xff08;二…

Ansible常用模塊

華子目錄 Ansible四個命令模塊1.組成2.特點3.區別3.1command、shell模塊3.2raw模塊 4.command模塊4.1參數表4.2free_form參數 5.shell模塊5.1作用5.2例如 6.script模塊6.1示例 7.raw模塊7.1參數7.2示例 文件操作模塊1.file模塊1.1參數1.2示例 2.copy模塊2.1參數 Ansible四個命令…