Django+Vue跨域環(huán)境配置詳解
概述
在使用Django+Vue開發(fā)過程中,遇到了很多開發(fā)環(huán)境相關(guān)的問題,比如跨域,比如ajax請(qǐng)求參數(shù)等,本篇文章主要記錄解決在開發(fā)過程中,遇到的一些問題。
跨域不帶Cookie
在使用Vue腳手架開發(fā)的過程中,會(huì)使用Vue腳手架自帶的Server進(jìn)行項(xiàng)目調(diào)試,Vue自帶的Server支持 hot reloading ,這個(gè)特性是非常好用的。但是在開發(fā)過程中,因?yàn)橐c后端交互,所以在請(qǐng)求后端接口的時(shí)候,會(huì)遇到跨域問題,這個(gè)問題在一些職責(zé)劃分清楚的團(tuán)隊(duì)并不存在,因?yàn)榍岸碎_發(fā)人員會(huì)才用Mock數(shù)據(jù)的方式。
Webpack配置
采用Webpack dev server的 proxyTable 即可實(shí)現(xiàn)代理,將請(qǐng)求轉(zhuǎn)發(fā)到后端的開發(fā)服務(wù)器上。配置方法如下:
proxyTable: {
'/api': {
target: 'http://127.0.0.1:8190/',
changeOrigin: true
},
'/manager': {
target: 'http://127.0.0.1:8000/',
changeOrigin: true,
}
}
將需要請(qǐng)求的真實(shí)地址在proxyTable里配置即可。
當(dāng)然,proxyTable還有需要更高級(jí)的用法,這里就先不去踩那些不必要的坑。
Django CORS頭配置
Django配置跨域,可以自己實(shí)現(xiàn),也可以使用一個(gè)比較好用的庫(kù) django-cors-headers 。
在Django的配置文件里添加如下配置:
(1) 在 INSTALLED_APPS 配置項(xiàng)里配置如下:
INSTALLED_APPS = ( ... 'corsheaders', ... )
(2) 在 MIDDLEWARE_CLASSES 配置項(xiàng)里配置如下:
MIDDLEWARE = [ # Or MIDDLEWARE_CLASSES on Django < 1.10 ... 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', ... ]
CorsMiddleware 的優(yōu)先級(jí)要盡可能的高,如在 CorsMiddleware 前邊。
(3)增加 CORS_ORIGIN_ALLOW_ALL 配置項(xiàng)
在配置文件里新增 CORS_ORIGIN_ALLOW_ALL 配置項(xiàng),并設(shè)置為True
CORS_ORIGIN_ALLOW_ALL = True
跨域帶Cookie
按照上面的配置對(duì) webpack 和 Django 進(jìn)行配置后,可以實(shí)現(xiàn)在Vue中進(jìn)行跨域Ajax請(qǐng)求,但是請(qǐng)求中并不帶Cookie,如果需要帶Cookie,則需要進(jìn)行如下配置。
Webpack配置
Webpack配置方法同不帶Cookie的方法相同。
Vue配置
在Vue里需要對(duì) axios 進(jìn)行全局配置,在 main.js 里增加如下配置:
axios.defaults.withCredentials = true
Django配置
如果需要在請(qǐng)求中帶上Cookie,Django中的跨域返回頭中就不能允許所有主機(jī),需要指定單獨(dú)主機(jī),配置如下:
CORS_ALLOW_CREDENTIALS = True CORS_ORIGIN_WHITELIST = ( 'localhost:8088', 'localhost:8000', '127.0.0.1:8088', '127.0.0.1:8000' ) CORS_ALLOW_HEADERS = ( 'x-csrftoken', )
其中 CORS_ALLOW_HEADERS 配置項(xiàng)允許在ajax請(qǐng)求中定義允許自定義的頭字段。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
解決vue-cli項(xiàng)目打包出現(xiàn)空白頁(yè)和路徑錯(cuò)誤的問題
今天小編就為大家分享一篇解決vue-cli項(xiàng)目打包出現(xiàn)空白頁(yè)和路徑錯(cuò)誤的問題。具有很好的參考價(jià)值。希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vue3為什么要用proxy替代defineProperty
這篇文章主要介紹了vue3為什么要用proxy替代defineProperty,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10
vue watch監(jiān)控對(duì)象的簡(jiǎn)單方法示例
這篇文章主要給大家介紹了關(guān)于vue watch監(jiān)控對(duì)象的簡(jiǎn)單方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
詳解vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能
這篇文章主要介紹了vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
Vue computed實(shí)現(xiàn)原理深入講解
computed又被稱作計(jì)算屬性,用于動(dòng)態(tài)的根據(jù)某個(gè)值或某些值的變化,來產(chǎn)生對(duì)應(yīng)的變化,computed具有緩存性,當(dāng)無關(guān)值變化時(shí),不會(huì)引起computed聲明值的變化。產(chǎn)生一個(gè)新的變量并掛載到vue實(shí)例上去2022-10-10
Vue如何動(dòng)態(tài)改變列表搜索出關(guān)鍵詞的字體顏色
這篇文章主要介紹了Vue如何動(dòng)態(tài)改變列表搜索出關(guān)鍵詞的字體顏色問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
Vue實(shí)戰(zhàn)記錄之登陸頁(yè)面的實(shí)現(xiàn)
最近學(xué)習(xí)過程中常碰到讓用戶登錄注冊(cè)這種,這篇文章主要給大家介紹了關(guān)于Vue實(shí)戰(zhàn)記錄之登陸頁(yè)面實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2021-06-06

