中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么處理Django+vue跨域問題

發布時間:2021-10-18 14:56:50 來源:億速云 閱讀:197 作者:小新 欄目:編程語言

小編給大家分享一下怎么處理Django+vue跨域問題,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

跨域

由于開發模式為前后端分離式開發,故而通常情況下,前端和后端可能運行不同的ip或者port下,導致出現跨域問題,故而單獨說明

什么是跨域

跨域是指一個域下的文檔或腳本試圖去請求另一個域下的資源,這里跨域是廣義的。
其實我們通常所說的跨域是狹義的,是由瀏覽器同源策略限制的一類請求場景。

什么是同源策略?

同源策略/SOP(Same origin policy)是一種約定,由Netscape公司1995年引入瀏覽器,它是瀏覽器最核心也最基本的安全功能,如果缺少了同源策略,瀏覽器很容易受到XSS、CSFR等***。所謂同源是指"協議+域名+端口"三者相同,即便兩個不同的域名指向同一個ip地址,也非同源。

同源策略限制以下幾種行為:

  1. Cookie、LocalStorage 和 IndexDB 無法讀取

  2. DOM 和 Js對象無法獲得

  3. AJAX 請求不能發送

跨域錯誤瀏覽器會在控制臺中出現如下錯誤:
報錯信息如下:

Access to XMLHttpRequest at 'http://127.0.0.1:8000/api/test/' from origin 'http://127.0.0.1:3000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

翻譯過來即是:從源地址 http://127.0.0.1:3000 發起的到http://127.0.0.1:8000/api/test/ 的XMLHttpRequest訪問違反了同源策略:因為在請求頭中沒有Access-Control-Allow-Origin的值

前端解決跨域

參考博客

既然跨域是因為不同源,那我同源不就完事兒了,但是后端請求地址不可能改變,所以可以在前端和后端的中間加一層代理,前端通過代理訪問后端。
在Vue-cli工具中已經提供了代理的功能,只需要配置即可。
在根目錄下的config/index.js文件中有如下配置項:

proxyTable: {      
    '/': { 
        target: 'http://127.0.0.1:8000/',        
        changeOrigin: true,        
        pathRewrite: {          
            '^/api': ''
        }
      }
    },
  • '/'表示以'/'(即所有的路徑)開頭的路徑均需要代理,

  • target:代理的目標服務器地址(即后端服務器地址)為 'http://127.0.0.1:8000/',

  • changeOrigin,為修改源:修改請求中的源地址

  • pathReWrite:URL路徑重寫,對于以'/api'開頭的路徑將'/api'替換為''

后端解決跨域

后端出于安全考慮,也會對于跨域有限制,解決方法如下:

安裝django-cors-headers

$ pip install django-cors-headers

配置settings.py文件

INSTALLED_APPS = [
    ...    'corsheaders',
    ...
 ] 

MIDDLEWARE = (
    ...    
    'corsheaders.middleware.CorsMiddleware',    
    'django.middleware.common.CommonMiddleware', # 注意順序
    ...
)

#跨域增加忽略
CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_ALLOW_ALL = True

CORS_ALLOW_METHODS = (    
    'DELETE',    
    'GET',    
    'OPTIONS',    
    'PATCH',    
    'POST',    
    'PUT',    
    'VIEW',
)

CORS_ALLOW_HEADERS = (    
    'XMLHttpRequest',    
    'X_FILENAME',    
    'accept-encoding',    
    'authorization',    
    'content-type',    
    'dnt',    
    'origin',    
    'user-agent',    
    'x-csrftoken',    
    'x-requested-with',    
    'Pragma',
)

看完了這篇文章,相信你對“怎么處理Django+vue跨域問題”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

太康县| 东源县| 定州市| 吴江市| 浠水县| 容城县| 湘西| 师宗县| 揭西县| 剑阁县| 南部县| 外汇| 隆回县| 穆棱市| 云阳县| 南京市| 华容县| 崇文区| 锡林浩特市| 洪江市| 彩票| 沽源县| 舒城县| 大石桥市| 卫辉市| 民和| 颍上县| 通辽市| 临猗县| 赞皇县| 铜川市| 文安县| 旬邑县| 宁武县| 彝良县| 论坛| 巴里| 茶陵县| 广水市| 泸溪县| 镶黄旗|