如何解決跨域資源共享(CORS)問題?

一、什麼是跨域資源共享問題?

Web應用程序通常會從不同的域(域名、端口或協議)請求數據。當瀏覽器在某個域上運行腳本時,它被限制只能腳本來源的域以及和該域共享同一來源的域(同源策略)。所以在跨域請求時就會出現跨域資源共享問題。

二、引發跨域的幾種場景及其解決方案

1、Ajax請求跨域

const xhr = new XMLHttpRequest();
const url = 'http://otherdomain.com/data';
xhr.open('GET', url);
xhr.withCredentials = true; // 設置xhr對象可以發送http cookie
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xhr.send();

解決方案:

服務器設置響應頭 Access-Control-Allow-Origin 添加來源源文件的IP地址或者域名。例如JavaScript代碼的執行環境處於 http://www.example.com/index.html,那麼Access-Control-Allow-Origin響應頭可以設置為 http://www.example.com,以允許該頁面所有的Ajax請求都能夠通過跨域限制。但是,如果Access-Control-Allow-Origin的值為*,則表示該資源誰都可以訪問。

res.setHeader('Access-Control-Allow-Origin', 'http://www.example.com');

2、圖片標籤、腳本標籤等跨域

<img src='http://www.imgdomain.com/image.jpg'/>
<script src='http://www.jsdomain.com/script.js'>

解決方案:

服務器設置CORS響應頭 Access-Control-Allow-Origin 即可。

res.setHeader('Access-Control-Allow-Origin', '*');

3、Web字體跨域

@font-face {
   font-family: 'MyFont';
   src: url('http://www.fontdomain.com/fonts/MyFont.woff');
}

解決方案:

服務器設置CORS響應頭 Access-Control-Allow-Origin 即可。

res.setHeader('Access-Control-Allow-Origin', '*');

4、跨站腳本攻擊(XSS)

<script>
  const username = 'Bob';
  document.cookie = `username=${username}`;
</script>

解決方案:

在服務端對任何輸入輸出進行過濾以及防範XSS攻擊等安全漏洞。

三、使用代理服務器的解決方案

以上方案解決跨域問題涉及到後端修改代碼,無法在開發階段解決。因此,一個通用的解決方案是使用代理服務器將所有請求轉發到同一域名下,然後在該域名下進行請求。這樣,對於瀏覽器而言就不會涉及到跨域問題了。比如使用webpack-dev-server的proxy配置,可以將所有請求轉發到本地的/api路徑下。

devServer: {
    proxy: {
      '/api': {
        target: 'http://localhost:3000',
        pathRewrite: {'^/api': ''}
      }
    }
  }

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/303605.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-31 11:50
下一篇 2024-12-31 11:50

相關推薦

  • Python官網中文版:解決你的編程問題

    Python是一種高級編程語言,它可以用於Web開發、科學計算、人工智能等領域。Python官網中文版提供了全面的資源和教程,可以幫助你入門學習和進一步提高編程技能。 一、Pyth…

    編程 2025-04-29
  • 如何解決WPS保存提示會導致宏不可用的問題

    如果您使用過WPS,可能會碰到在保存的時候提示“文件中含有宏,保存將導致宏不可用”的問題。這個問題是因為WPS在默認情況下不允許保存帶有宏的文件,為了解決這個問題,本篇文章將從多個…

    編程 2025-04-29
  • 如何解決dlib庫安裝失敗

    如果您遇到了dlib庫安裝失敗的問題,在此文章中,我們將從多個方面對這個問題進行詳細的闡述,並給出解決方法。 一、檢查環境安裝情況 1、首先,您需要確認是否安裝了C++編譯器和Py…

    編程 2025-04-29
  • 如何解決web瀏覽器雙擊事件時差

    本文將從以下幾個方面對web瀏覽器雙擊事件時差進行詳細闡述,並提供解決方法。 一、雙擊事件延時設置 1、問題描述:在web瀏覽器中,雙擊事件默認會延時一定的時間才能觸發該事件,這個…

    編程 2025-04-29
  • Java Thread.start() 執行幾次的相關問題

    Java多線程編程作為Java開發中的重要內容,自然會有很多相關問題。在本篇文章中,我們將以Java Thread.start() 執行幾次為中心,為您介紹這方面的問題及其解決方案…

    編程 2025-04-29
  • Python爬蟲亂碼問題

    在網絡爬蟲中,經常會遇到中文亂碼問題。雖然Python自帶了編碼轉換功能,但有時候會出現一些比較奇怪的情況。本文章將從多個方面對Python爬蟲亂碼問題進行詳細的闡述,並給出對應的…

    編程 2025-04-29
  • NodeJS 建立TCP連接出現粘包問題

    在TCP/IP協議中,由於TCP是面向字節流的協議,發送方把需要傳輸的數據流按照MSS(Maximum Segment Size,最大報文段長度)來分割成若干個TCP分節,在接收端…

    編程 2025-04-29
  • 如何解決vuejs應用在nginx非根目錄下部署時訪問404的問題

    當我們使用Vue.js開發應用時,我們會發現將應用部署在nginx的非根目錄下時,訪問該應用時會出現404錯誤。這是因為Vue在刷新頁面或者直接訪問非根目錄的路由時,會認為服務器上…

    編程 2025-04-29
  • 如何解決egalaxtouch設備未找到的問題

    egalaxtouch設備未找到問題通常出現在Windows或Linux操作系統上。如果你遇到了這個問題,不要慌張,下面我們從多個方面進行詳細闡述解決方案。 一、檢查硬件連接 首先…

    編程 2025-04-29
  • Python折扣問題解決方案

    Python的折扣問題是在計算購物車價值時常見的問題。在計算時,需要將原價和折扣價相加以得出最終的價值。本文將從多個方面介紹Python的折扣問題,並提供相應的解決方案。 一、Py…

    編程 2025-04-28

發表回復

登錄後才能評論