国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Django+Vue跨域環境配置詳解

2024-05-06 15:32:55
字體:
來源:轉載
供稿:網友

概述

在使用Django+Vue開發過程中,遇到了很多開發環境相關的問題,比如跨域,比如ajax請求參數等,本篇文章主要記錄解決在開發過程中,遇到的一些問題。

跨域不帶Cookie

在使用Vue腳手架開發的過程中,會使用Vue腳手架自帶的Server進行項目調試,Vue自帶的Server支持 hot reloading ,這個特性是非常好用的。但是在開發過程中,因為要與后端交互,所以在請求后端接口的時候,會遇到跨域問題,這個問題在一些職責劃分清楚的團隊并不存在,因為前端開發人員會才用Mock數據的方式。

Webpack配置

采用Webpack dev server的 proxyTable 即可實現代理,將請求轉發到后端的開發服務器上。配置方法如下:

proxyTable: { '/api': {  target: 'http://127.0.0.1:8190/',  changeOrigin: true }, '/manager': {  target: 'http://127.0.0.1:8000/',  changeOrigin: true, }}

將需要請求的真實地址在proxyTable里配置即可。

當然,proxyTable還有需要更高級的用法,這里就先不去踩那些不必要的坑。

Django CORS頭配置

Django配置跨域,可以自己實現,也可以使用一個比較好用的庫 django-cors-headers 。

在Django的配置文件里添加如下配置:

(1) 在 INSTALLED_APPS 配置項里配置如下:

INSTALLED_APPS = (  ...  'corsheaders',  ...)

(2) 在 MIDDLEWARE_CLASSES 配置項里配置如下:

MIDDLEWARE = [ # Or MIDDLEWARE_CLASSES on Django < 1.10  ...  'corsheaders.middleware.CorsMiddleware',  'django.middleware.common.CommonMiddleware',  ...]

CorsMiddleware 的優先級要盡可能的高,如在 CorsMiddleware 前邊。

(3)增加 CORS_ORIGIN_ALLOW_ALL 配置項

在配置文件里新增 CORS_ORIGIN_ALLOW_ALL 配置項,并設置為True

CORS_ORIGIN_ALLOW_ALL = True

跨域帶Cookie

按照上面的配置對 webpack Django 進行配置后,可以實現在Vue中進行跨域Ajax請求,但是請求中并不帶Cookie,如果需要帶Cookie,則需要進行如下配置。

Webpack配置

Webpack配置方法同不帶Cookie的方法相同。

Vue配置

在Vue里需要對 axios 進行全局配置,在 main.js 里增加如下配置:

axios.defaults.withCredentials = true

Django配置

如果需要在請求中帶上Cookie,Django中的跨域返回頭中就不能允許所有主機,需要指定單獨主機,配置如下:

CORS_ALLOW_CREDENTIALS = TrueCORS_ORIGIN_WHITELIST = (  'localhost:8088',  'localhost:8000',  '127.0.0.1:8088',  '127.0.0.1:8000')CORS_ALLOW_HEADERS = (  'x-csrftoken',)            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 多伦县| 砚山县| 庐江县| 娄底市| 会理县| 盐亭县| 疏附县| 陆良县| 沈阳市| 浦江县| 武功县| 敦煌市| 连山| 土默特右旗| 石门县| 甘德县| 宁强县| 廉江市| 泰顺县| 晋江市| 衡山县| 大余县| 九江县| 南江县| 台山市| 宁明县| 繁峙县| 咸阳市| 苏尼特右旗| 河北区| 桃江县| 民县| 萨嘎县| 墨脱县| 沈阳市| 郯城县| 镇康县| 清水县| 株洲市| 南开区| 友谊县|