【记录】Django解决与VUE跨域问题

1 梗概

这里记录Django与VUE的跨域问题解决方法,主要修改内容是在 Django 中。当然其他的前端项目 Django 也可以这样处理。

2 安装辅助包

pip install django-cors-headers

3 配置 settings.py

INSTALLED_APPS = [

...

'corsheaders',

...

]

为了响应头的处理,更新MIDDLEWARE设置,确保CorsMiddleware位于适当的位置:

MIDDLEWARE = [

确保CorsMiddleware放置在可以生成响应的中间件之前,例如CommonMiddleware之前。

'corsheaders.middleware.CorsMiddleware',

'django.middleware.common.CommonMiddleware',

其他中间件...

同时可注释掉

'django.middleware.csrf.CsrfViewMiddleware',

]

可以通过设置CORS_ALLOWED_ORIGINS来指定哪些域被允许访问你的API:

CORS_ALLOWED_ORIGINS = [

"http://example.com",

"https://another-example.com",

]

若在开发阶段希望允许任何源,可以暂时设置为:

CORS_ALLOW_ALL_ORIGINS = True

开发过程中 可在settings.py 中增加下面的内容,

CORS_ALLOW_CREDENTIALS = True
CORS_ALLOW_ALL_ORIGINS = True
CORS_ALLOW_HEADERS = ('*')

【注】在生产环境中应该明确限制来源以增强安全性

相关推荐
程序猿000001号22 分钟前
使用Python的Turtle库绘制图形:初学者指南
开发语言·python
西猫雷婶1 小时前
python学opencv|读取图像(十一)彩色图像转灰度图的两种办法
开发语言·人工智能·python·opencv·计算机视觉
程序员黄同学1 小时前
如何使用 Python 读取文本文件?
开发语言·python
珂朵莉MM1 小时前
第六届全球校园人工智能算法精英大赛-算法巅峰专项赛(系列文章)-- 开篇
java·人工智能·python·算法·职场和发展
油泼辣子多加1 小时前
【计算机视觉】边缘检测
人工智能·python·计算机视觉
灵封~1 小时前
Python机器视觉的学习
python·学习·计算机视觉
虚假程序设计1 小时前
python在纯文本程序里面藏一张图
开发语言·python
NiNg_1_2341 小时前
Python中PyTorch详解
开发语言·pytorch·python
web安全工具库2 小时前
探索 Python 中的字典:序列解包与复杂数据结构
前端·数据库·python
有蝉2 小时前
vue-echarts@6.7.3 readme
前端·vue.js·echarts