我在Django后端处理前端发来的请求没有处理了OPTIONS请求只处理POST请求 可是在提交表单的时候 我发现django后端同时接受了两个请求 如下图
先发送了OPTIONS才发送POST导致POST请求没有被处理!怎么办!
vue前端和django后端在处理请求方面的问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- bilal-abdurehim 2023-03-28 20:04关注
这是由于浏览器发送了一个 CORS 预检请求(OPTIONS 请求),以确定是否允许 POST 请求。要解决此问题,您需要在 Django 后端添加一些 CORS 设置以允许跨域请求。您可以尝试使用现有的 Django 库,例如 django-cors-headers。
django-cors-headers 是一个Django第三方包,可以轻松地为您的Django应用程序添加CORS头。它提供了一个中间件,可以添加CORS标头以允许跨域请求。
您可以使用以下步骤安装 django-cors-headers:
- 通过 pip 安装 django-cors-headers:
pip install django-cors-headers
- 在您的 Django 项目的 settings.py 文件中添加以下内容来启用 django-cors-headers:
INSTALLED_APPS = [ # ... 'corsheaders', # ... ] MIDDLEWARE = [ # ... 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', # ... ] CORS_ALLOWED_ORIGINS = [ # 添加您允许跨域请求的域名 '<http://localhost:8080>', '<http://127.0.0.1:8080>', ] CORS_ALLOW_METHODS = [ 'DELETE', 'GET', 'OPTIONS', 'PATCH', 'POST', 'PUT', ] CORS_ALLOW_HEADERS = [ 'accept', 'accept-encoding', 'authorization', 'content-type', 'dnt', 'origin', 'user-agent', 'x-csrftoken', 'x-requested-with', ]
- 重新启动您的 Django 项目,并尝试提交表单,看看是否成功处理了 POST 请求。
请注意,这只是一种解决方法。如果您的应用程序需要更严格的安全性设置,请考虑使用其他安全措施,如 CSRF 保护。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
- ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
- ¥15 帮我写一个c++工程
- ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
- ¥15 关于smbclient 库的使用
- ¥15 微信小程序协议怎么写
- ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
- ¥20 怎么用dlib库的算法识别小麦病虫害
- ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
- ¥15 uniapp uview http 如何实现统一的请求异常信息提示?