因爲開發模式爲先後端分離式開發,故而一般狀況下,前端和後端可能運行不一樣的ip或者port下,致使出現跨域問題,故而單獨說明
跨域是指一個域下的文檔或腳本試圖去請求另外一個域下的資源,這裏跨域是廣義的。
其實咱們一般所說的跨域是狹義的,是由瀏覽器同源策略限制的一類請求場景。前端
什麼是同源策略?django
同源策略/SOP(Same origin policy)是一種約定,由Netscape公司1995年引入瀏覽器,它是瀏覽器最核心也最基本的安全功能,若是缺乏了同源策略,瀏覽器很容易受到XSS、CSFR等攻擊。所謂同源是指"協議+域名+端口"三者相同,即使兩個不一樣的域名指向同一個ip地址,也非同源。segmentfault
同源策略限制如下幾種行爲:後端
跨域錯誤瀏覽器會在控制檯中出現以下錯誤:
報錯信息以下:api
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': '' } } },
參考博客服務器
後端出於安全考慮,也會對於跨域有限制,解決方法以下:app
安裝django-cors-headers
$ pip install django-cors-headers
配置settings.py文件
INSTALLED_APPS = [ ... 'corsheaders', ... ] MIDDLEWARE_CLASSES = ( ... 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', # 注意順序 ... ) #跨域增長忽略 CORS_ALLOW_CREDENTIALS = True CORS_ORIGIN_ALLOW_ALL = True CORS_ORIGIN_WHITELIST = ( '*' ) 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', )