我在Django后端处理前端发来的请求没有处理了OPTIONS请求只处理POST请求 可是在提交表单的时候 我发现django后端同时接受了两个请求 如下图
先发送了OPTIONS才发送POST导致POST请求没有被处理!怎么办!
这是由于浏览器发送了一个 CORS 预检请求(OPTIONS 请求),以确定是否允许 POST 请求。要解决此问题,您需要在 Django 后端添加一些 CORS 设置以允许跨域请求。您可以尝试使用现有的 Django 库,例如 django-cors-headers。
django-cors-headers 是一个Django第三方包,可以轻松地为您的Django应用程序添加CORS头。它提供了一个中间件,可以添加CORS标头以允许跨域请求。
您可以使用以下步骤安装 django-cors-headers:
pip install 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',
]
请注意,这只是一种解决方法。如果您的应用程序需要更严格的安全性设置,请考虑使用其他安全措施,如 CSRF 保护。
或者使用curl命令实现POST提交数据的测试
$ curl -X POST -d "username=admin&password=admin123" http://localhost:8000/jwt-auth/