欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何解決Django+vue跨域問(wèn)題

小編給大家分享一下如何解決Django+vue跨域問(wèn)題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)公司作為成都網(wǎng)站建設(shè)公司,專注成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì),有關(guān)企業(yè)網(wǎng)站設(shè)計(jì)方案、改版、費(fèi)用等問(wèn)題,行業(yè)涉及咖啡廳設(shè)計(jì)等多個(gè)領(lǐng)域,已為上千家企業(yè)服務(wù),得到了客戶的尊重與認(rèn)可。

跨域

由于開發(fā)模式為前后端分離式開發(fā),故而通常情況下,前端和后端可能運(yùn)行不同的ip或者port下,導(dǎo)致出現(xiàn)跨域問(wèn)題,故而單獨(dú)說(shuō)明

什么是跨域

跨域是指一個(gè)域下的文檔或腳本試圖去請(qǐng)求另一個(gè)域下的資源,這里跨域是廣義的。

其實(shí)我們通常所說(shuō)的跨域是狹義的,是由瀏覽器同源策略限制的一類請(qǐng)求場(chǎng)景。

什么是同源策略?

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

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

  1. Cookie、LocalStorage 和 IndexDB 無(wú)法讀取

  2. DOM 和 Js對(duì)象無(wú)法獲得

  3. AJAX 請(qǐng)求不能發(fā)送

跨域錯(cuò)誤瀏覽器會(huì)在控制臺(tái)中出現(xiàn)如下錯(cuò)誤:

報(bào)錯(cuò)信息如下:

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.

翻譯過(guò)來(lái)即是:從源地址 http://127.0.0.1 :3000 發(fā)起的到 http://127.0.0.1 :8000/api/test/ 的XMLHttpRequest訪問(wèn)違反了同源策略:因?yàn)樵谡?qǐng)求頭中沒有Access-Control-Allow-Origin的值

前端解決跨域

參考博客 

既然跨域是因?yàn)椴煌?,那我同源不就完事兒了,但是后端?qǐng)求地址不可能改變,所以可以在前端和后端的中間加一層代理,前端通過(guò)代理訪問(wèn)后端。

在Vue-cli工具中已經(jīng)提供了代理的功能,只需要配置即可。

在根目錄下的config/index.js文件中有如下配置項(xiàng):

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

  2. target:代理的目標(biāo)服務(wù)器地址(即后端服務(wù)器地址)為 ' http://127.0.0.1 :8000/',

  3. changeOrigin,為修改源:修改請(qǐng)求中的源地址

  4. pathReWrite:URL路徑重寫,對(duì)于以'/api'開頭的路徑將'/api'替換為''

后端解決跨域

參考博客 

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

安裝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',
)

以上是“如何解決Django+vue跨域問(wèn)題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

本文名稱:如何解決Django+vue跨域問(wèn)題
網(wǎng)站網(wǎng)址:http://aaarwkj.com/article36/jeijpg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃、虛擬主機(jī)、網(wǎng)站排名、外貿(mào)建站、用戶體驗(yàn)建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)
涩久久悠悠一区二区三区| 日本大型午夜福利视频| 亚洲国产精品一区一区| 亚洲视频一直看一直爽| 亚洲欧美二区中文字幕| 色播五月麻豆激情综合网| 日本岛国大片一区二区在线观看| 黄色av免费播放网站| av中文字幕熟妇人妻少妇| 中国人妻一区二区三区| 婷婷丁香久久五月婷婷| 亚洲国产欧美一区三区成人| 亚洲欧美日韩午夜在线| 国产黄的网站在线观看| 日韩精品在线观看不卡| 人妻熟女一区二区视频| 亚洲激情欧美激情在线| 羞羞的视频免费观看在线| 欧美十八一区二区三区| 国产中文字二暮区2021综合| 久久精品国产亚洲av无| 亚洲一二三无人区是什么| 国产级一片内射视步页| 91人妻这里只有精品| 成年人在线观看免费观看| 日韩激情一区二区三区| 欧美偷拍一区二区三区| 日韩精品高清中文字幕| 日本大片在线一区二区三区| 精品亚洲国产一区二区三区| 在线观看一区二区三区国产视频| 黄色日韩欧美在线观看| 天堂久久天堂av色综合| 在线观看中文字幕一区| 18禁污污网站国产| 欧美香蕉视频播放二区| 国产日韩精品免费在线| 91九色国产在线播放| 99精品人妻一区二区三区| 精品在线中文字幕不卡| 毛片精品一区二区二区三区|