我正在尝试在简单的 django rest 服务器上启用 CORS。
我已遵循此处的建议 How can I enable CORS on Django REST Framework .
具体来说,我有:
1) 完成
pip install django-cors-headers
2)
为我安装的应用程序添加了 corsheaders
3) 在我的 Django 设置文件的 MIDDLEWARE 部分的顶部添加了 corsheaders.middleware.CorsMiddleware
4) 添加
CORS_ORIGIN_ALLOW_ALL = True
CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_WHITELIST = (
'localhost:3000/radioDestinations/',
'localhost:8080',
)
但是还是不行。
当我向服务器发送请求(使用 javascript 获取请求)时,我在浏览器中收到错误消息(...被 CORS 策略阻止:不存在“Access-Control-Allow-Origin” header ... ), 但我在服务控制台中没有得到任何输出。
如何找出问题所在?
最佳答案
django-cors-headers
相当简单,您的配置对我来说似乎是正确的。
但是我遇到了一个问题,这可能也是你的问题:
如果您将服务器配置为在不调用 Django/Python 的情况下提供静态文件(很常见,即使在内置服务器上也是如此),django-cors-headers
无法将 CORS header 应用于这些响应。取决于浏览器,this will cause problems with asynchronous requests, fonts and sometimes even images, video and audio.
关于javascript - 如何在我的 Django REST api 上调试启用 CORS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52244162/