Django 在 AWS S3 中托管静态文件,在尝试访问管理字体文件时导致 CORS 错误

Alv*_*ler 11 django amazon-s3 django-admin django-rest-framework

我将 Django 设置为将所有静态文件存储在 S3 上,并使用“collectstatic”命令复制所有管理文件,并且当我访问管理站点时,CSS 和 JS 文件均正确源自 S3 存储桶。例如:

https://bucket.s3.amazonaws.com/static/admin/css/base.css
https://bucket.s3.amazonaws.com/static/admin/js/vendor/jquery/jquery.js
Run Code Online (Sandbox Code Playgroud)

但是当它尝试访问字体文件 .woff 时,我收到以下错误:

Access to font at 'https://bucket.s3.amazonaws.com/static/admin/fonts/Roboto-Light-webfont.woff' from origin 'http://localhost:8000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
Run Code Online (Sandbox Code Playgroud)

奇怪的是,它让我可以访问除字体文件之外的所有文件:

在此输入图像描述

eld*_*dos 8

在 S3 存储桶权限 > CORS 中配置以下内容修复了该问题。

[
    {
        "AllowedHeaders": [
            "Authorization"
        ],
        "AllowedMethods": [
            "GET"
        ],
        "AllowedOrigins": [
            "*"
        ],
        "ExposeHeaders": [],
        "MaxAgeSeconds": 3000
    },
    {
        "AllowedHeaders": [
            "*"
        ],
        "AllowedMethods": [
            "HEAD",
            "GET",
            "PUT",
            "POST",
            "DELETE"
        ],
        "AllowedOrigins": [
            "*"
        ],
        "ExposeHeaders": [
            "ETag",
            "x-amz-meta-custom-header"
        ]
    }
]
Run Code Online (Sandbox Code Playgroud)


You*_*Alm 0

我记得我之前在使用 Google Cloud Storage 时遇到过这个问题。

您必须使您的存储桶允许来源跨入您的域。