数字海洋 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 错误

减少 django 上的用户 CPU 时间

Nginx 和乘客依赖问题(数字海洋部署)

Docker + Gunicorn + Nginx + Django:将非 www 重定向到 AWS Route 53 上的 www

Nginx 无法在数字海洋上提供 django 静态或媒体文件

Nginx + Gunicorn + Django Stack 上的站点缓慢故障排除