数字海洋 NGINX 和 gunicorn 上的 CORS 标头访问控制缺少 django
Posted
技术标签:
【中文标题】数字海洋 NGINX 和 gunicorn 上的 CORS 标头访问控制缺少 django【英文标题】:CORS header access control missing django on digital ocean NGINX and gunicorn 【发布时间】:2018-09-12 06:02:05 【问题描述】:控制台响应:-
跨域请求被阻止:同源策略不允许读取位于https://blissedmaths.sgp1.digitaloceanspaces.com/media/topics/4276769703/4276769703.svg 的远程资源。 (原因:缺少 CORS 标头“Access-Control-Allow-Origin”)。
我有用户 django-cors-headers,这是一个 Django 应用程序,可将 CORS(跨域资源共享)标头添加到响应中。
我的setting.py文件是
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'corsheaders',
'students',
'commons',
]
CORS_ORIGIN_ALLOW_ALL = True
CORS_ALLOW_CREDENTIALS = True
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',
)
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'corsheaders.middleware.CorsMiddleware',
'django.middleware.common.CommonMiddleware',
]
来自数字海洋空间给我错误的图像是
<script>
function fetchXML(url, callback)
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true);
xhr.withCredentials = true;
xhr.setRequestHeader('Access-Control-Allow-Origin' , '*');
console.log(xhr.getAllResponseHeaders)
xhr.onreadystatechange = function (evt)
//Do not explicitly handle errors, those should be
//visible via console output in the browser.
if (xhr.readyState === 4)
callback(xhr.responseXML);
;
xhr.send(null);
;
fetchXML("a.image.url",function(newSVGDoc)
//import it into the current DOM
var n = document.importNode(newSVGDoc.documentElement,true);
document.querySelector('.a.topic|slugify-image').appendChild(n);
);
</script>
此页面位于https://blissedmaths.com/myclas-s-room/polynomial/
我已经在 setting.py 中添加了所有需要的东西,但标题仍然没有出现。我也尝试过 Jquery 和 AJAX。但是没用。
如何解决这个问题。 是否还需要一些 javascript 或仅此后端就足够了?
我也尝试通过 nginx conf 添加标头。但是没有用。 我如何通过 python 代码或 Jquery/JS 或服务器配置文件来解决这个问题。实际上没有任何方法对我有用。但图像来自源。 请为此提供修复。
【问题讨论】:
这个问题你解决了吗? 我知道这已经有一段时间了,但是你有没有机会解决这个问题? 【参考方案1】:设置文件中有两个“django.middleware.common.CommonMiddleware”。 CorsMiddleware 应该放在尽可能高的位置,尤其是在任何可以生成响应的中间件之前,例如 Django 的 CommonMiddleware
【讨论】:
谢谢Jibin,我试过了,还是不行。 删除 xhr.setRequestHeader('Access-Control-Allow-Origin' , '*');试试看 我做了,没有好处。 你解决了吗?以上是关于数字海洋 NGINX 和 gunicorn 上的 CORS 标头访问控制缺少 django的主要内容,如果未能解决你的问题,请参考以下文章
在 ubuntu 20.04 上部署 django 项目时出现 systemctl status gunicorn 错误
Docker + Gunicorn + Nginx + Django:将非 www 重定向到 AWS Route 53 上的 www