lily-cure 2023-03-28 19:58 采纳率: 81.3%
浏览 12
已结题

vue前端和django后端在处理请求方面的问题

我在Django后端处理前端发来的请求没有处理了OPTIONS请求只处理POST请求 可是在提交表单的时候 我发现django后端同时接受了两个请求 如下图
先发送了OPTIONS才发送POST导致POST请求没有被处理!怎么办!

img

  • 写回答

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:

    1. 通过 pip 安装 django-cors-headers:
    pip install django-cors-headers
    
    1. 在您的 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',
    ]
    
    1. 重新启动您的 Django 项目,并尝试提交表单,看看是否成功处理了 POST 请求。

    请注意,这只是一种解决方法。如果您的应用程序需要更严格的安全性设置,请考虑使用其他安全措施,如 CSRF 保护。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月5日
  • 已采纳回答 3月28日
  • 创建了问题 3月28日

悬赏问题

  • ¥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 如何实现统一的请求异常信息提示?