Loading [MathJax]/jax/input/TeX/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何使用django-storages和亚马逊S3设置Django项目,但使用不同的文件夹存放静态文件和媒体文件?

如何使用django-storages和亚马逊S3设置Django项目,但使用不同的文件夹存放静态文件和媒体文件?
EN

Stack Overflow用户
提问于 2012-04-30 20:36:55
回答 4查看 31.6K关注 0票数 95

我正在配置一个使用服务器文件系统来存储应用程序静态文件(STATIC_ROOT)和用户上传文件(MEDIA_ROOT)的Django项目。

我现在需要在亚马逊的S3上托管所有内容,所以我为此创建了一个存储桶。使用带有boto存储后端的django-storages,我设法将收集的静态数据上传到S3存储桶:

代码语言:javascript
运行
AI代码解释
复制
MEDIA_ROOT = '/media/'
STATIC_ROOT = '/static/'

DEFAULT_FILE_STORAGE = 'storages.backends.s3boto.S3BotoStorage'
AWS_ACCESS_KEY_ID = 'KEY_ID...'
AWS_SECRET_ACCESS_KEY = 'ACCESS_KEY...'
AWS_STORAGE_BUCKET_NAME = 'bucket-name'
STATICFILES_STORAGE = 'storages.backends.s3boto.S3BotoStorage'

然后,我遇到了一个问题:存储桶中没有使用MEDIA_ROOTSTATIC_ROOT,因此存储桶根目录包含静态文件和用户上传的路径。

这样我就可以设置:

代码语言:javascript
运行
AI代码解释
复制
S3_URL = 'http://s3.amazonaws.com/%s' % AWS_STORAGE_BUCKET_NAME
STATIC_URL = S3_URL + STATIC_ROOT
MEDIA_URL = 'S3_URL + MEDIA_ROOT

并在模板中使用这些设置,但在使用django-storages存储在S3中时,没有静态/媒体文件的区别。

如何做到这一点?

谢谢!

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-05-30 23:32:46

我认为下面的方法应该是可行的,而且比Mandx的方法更简单,尽管它非常相似:

创建s3utils.py文件:

代码语言:javascript
运行
AI代码解释
复制
from storages.backends.s3boto import S3BotoStorage

StaticRootS3BotoStorage = lambda: S3BotoStorage(location='static')
MediaRootS3BotoStorage  = lambda: S3BotoStorage(location='media')

然后在你的settings.py

代码语言:javascript
运行
AI代码解释
复制
DEFAULT_FILE_STORAGE = 'myproject.s3utils.MediaRootS3BotoStorage'
STATICFILES_STORAGE = 'myproject.s3utils.StaticRootS3BotoStorage'

在两个example_文件here中可以看到一个不同但相关的示例(我已经实际测试过了)。

票数 127
EN

Stack Overflow用户

发布于 2012-05-16 20:31:09

我目前在一个独立的s3utils模块中使用此代码:

代码语言:javascript
运行
AI代码解释
复制
from django.core.exceptions import SuspiciousOperation
from django.utils.encoding import force_unicode

from storages.backends.s3boto import S3BotoStorage


def safe_join(base, *paths):
    """
    A version of django.utils._os.safe_join for S3 paths.

    Joins one or more path components to the base path component intelligently.
    Returns a normalized version of the final path.

    The final path must be located inside of the base path component (otherwise
    a ValueError is raised).

    Paths outside the base path indicate a possible security sensitive operation.
    """
    from urlparse import urljoin
    base_path = force_unicode(base)
    paths = map(lambda p: force_unicode(p), paths)
    final_path = urljoin(base_path + ("/" if not base_path.endswith("/") else ""), *paths)
    # Ensure final_path starts with base_path and that the next character after
    # the final path is '/' (or nothing, in which case final_path must be
    # equal to base_path).
    base_path_len = len(base_path) - 1
    if not final_path.startswith(base_path) \
       or final_path[base_path_len:base_path_len + 1] not in ('', '/'):
        raise ValueError('the joined path is located outside of the base path'
                         ' component')
    return final_path


class StaticRootS3BotoStorage(S3BotoStorage):
    def __init__(self, *args, **kwargs):
        super(StaticRootS3BotoStorage, self).__init__(*args, **kwargs)
        self.location = kwargs.get('location', '')
        self.location = 'static/' + self.location.lstrip('/')

    def _normalize_name(self, name):
        try:
            return safe_join(self.location, name).lstrip('/')
        except ValueError:
            raise SuspiciousOperation("Attempted access to '%s' denied." % name)


class MediaRootS3BotoStorage(S3BotoStorage):
    def __init__(self, *args, **kwargs):
        super(MediaRootS3BotoStorage, self).__init__(*args, **kwargs)
        self.location = kwargs.get('location', '')
        self.location = 'media/' + self.location.lstrip('/')

    def _normalize_name(self, name):
        try:
            return safe_join(self.location, name).lstrip('/')
        except ValueError:
            raise SuspiciousOperation("Attempted access to '%s' denied." % name)

然后,在我的设置模块中:

代码语言:javascript
运行
AI代码解释
复制
DEFAULT_FILE_STORAGE = 'myproyect.s3utils.MediaRootS3BotoStorage'
STATICFILES_STORAGE = 'myproyect.s3utils.StaticRootS3BotoStorage'

我必须重新定义_normalize_name()私有方法,以使用safe_join()函数的“固定”版本,因为原始代码为合法路径提供了SuspiciousOperation异常。

我张贴这篇文章以供考虑,如果有人能给出更好的答案或改进这个答案,我们将非常欢迎。

票数 8
EN

Stack Overflow用户

发布于 2014-10-01 16:15:28

我认为答案很简单,默认情况下是这样做的。这在Django 1.6.5和Boto 2.28.0的AWS Elastic Beanstalk上对我有效:

代码语言:javascript
运行
AI代码解释
复制
STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
)

TEMPLATE_LOADERS = (
    'django.template.loaders.filesystem.Loader',
    'django.template.loaders.app_directories.Loader',
)

DEFAULT_FILE_STORAGE = 'storages.backends.s3boto.S3BotoStorage'
STATICFILES_STORAGE = 'storages.backends.s3boto.S3BotoStorage'
AWS_ACCESS_KEY_ID = os.environ['AWS_ACCESS_KEY_ID']
AWS_SECRET_ACCESS_KEY = os.environ['AWS_SECRET_KEY']

AWS密钥是从容器配置文件传入的,我根本没有设置STATIC_ROOTSTATIC_URL。此外,也不需要s3utils.py文件。这些详细信息由存储系统自动处理。这里的技巧是,我需要在我的模板中正确地、动态地引用这个未知路径。例如:

代码语言:javascript
运行
AI代码解释
复制
<link rel="icon" href="{% static "img/favicon.ico" %}">

这就是我如何处理我的favicon,它位于~/Projects/my_app/project/my_app/static/img/favicon.ico的本地(部署前)。

当然,我有一个单独的local_settings.py文件,用于在开发环境中本地访问这些东西,并且它确实有静态和媒体设置。我不得不做了大量的实验和阅读来找到这个解决方案,并且它一直工作,没有错误。

我理解您需要静态和根目录的分离,并且考虑到您只能提供一个存储桶,我要指出的是,此方法获取~/Projects/my_app/project/my_app/static/下我的本地环境中的所有文件夹,并在存储桶根目录下创建一个文件夹(即S3bucket/img/,如上面的示例所示)。所以你确实得到了文件的分离。例如,您可以在static文件夹中有一个media文件夹,并通过以下模板访问它:

代码语言:javascript
运行
AI代码解释
复制
{% static "media/" %}

我希望这能帮到你。我来到这里寻找答案,并更加努力地寻找一个比扩展存储系统更简单的解决方案。相反,我阅读了有关Boto的预期用途的文档,我发现我需要的很多东西都是默认内置的。干杯!

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10390244

复制
相关文章
分离django中的媒体文件,静态文件
django项目中,占很大体积的是静态文件,媒体文件还有html代码,那我们该如何把它们分离出来以方便我们和服务器去管理和使用它们。
py3study
2020/01/05
1.7K0
Django 项目中添加静态文件夹
在 mysite 文件夹下添加一个 statics 文件夹用来存放 js 文件
py3study
2020/01/16
6830
Django 项目中添加静态文件夹
Django静态文件的处理,static 和media 文件夹的配置
也就是我们创建一个django项目之后,就要首先处理静态文件,让项目可以找到静态文件。具体步骤是
一写代码就开心
2020/12/01
8490
Django静态文件的处理,static 和media 文件夹的配置
使用sqlserver来存放和取得session
第一种是我们经常用的,第2中就是使用一个名为 state server 的机器用它的内存来存放其他机器的session 状态,其实,我们还可以在 sql server 里面来存放和取得 session。是不是第一次听说。
Java架构师必看
2021/03/22
5090
如何在CentOS 7上使用Postgres,Nginx和Gunicorn设置Django
Django是一个功能强大的Web框架,可以帮助您启动Python应用程序或网站。Django包含一个简化的开发服务器,用于在本地测试您的代码,但是对于任何与生产相关的细节,都需要一个更安全,更强大的Web服务器。
angel_郁
2018/10/25
2.3K0
如何在Debian 10上使用Postgres,Nginx和Gunicorn设置Django
Django是一个功能强大的Web框架,可以帮助您实现Python应用程序或网站。 Django包含一个简化的开发服务器,用于在本地测试您的代码,但对于任何与生产相关的内容,都需要更安全,更强大的Web服务器。
子润先生
2021/06/16
6K0
如何在Debian 9上使用Postgres,Nginx和Gunicorn设置Django
Django是一个功能强大的Web框架,可以帮助您实现Python应用程序或网站。Django包含一个简化的开发服务器,用于在本地测试您的代码,但是对于任何与生产相关的细节,都需要一个更安全,更强大的Web服务器。
大瓜皮
2018/11/05
6.5K0
如何在Ubuntu 18.04上使用Postgres,Nginx和Gunicorn设置Django
Django是一个功能强大的Web框架,可以帮助您实现Python应用程序或网站。Django包含一个简化的开发服务器,用于在本地测试您的代码,但是对于任何与生产相关的细节,都需要一个更安全,更强大的Web服务器。
乌鸦
2018/10/25
6.6K0
如何在Debian 8上使用Postgres,Nginx和Gunicorn设置Django
Django是一个功能强大的Web框架,可以帮助您完成Python应用程序或网站。Django包含一个简化的开发服务器,用于在本地测试您的代码,但是对于任何与生产相关的细节,都需要一个更安全,更强大的Web服务器。
SQL GM
2018/08/10
3.9K0
【Django】 开发:静态文件,应用和模型层
指定访问静态文件时是需要通过 /static/xxx 或 127.0.0.1:8000/static/xxx
杨丝儿
2022/02/24
1.9K0
【Django】 开发:静态文件,应用和模型层
Ubuntu 文件文件夹查看权限和设置权限
-rw-r--r-- (644) 只有所有者才有读和写的权限,组群和其他人只有读的权限
用户5005176
2021/08/25
13.5K0
使用Android MediaPlayer播放媒体文件
我们平时利用Android手机娱乐最常见的方式莫过于听歌和看电影了,当然还有玩游戏,当然,这里我要说的是针对Android对于媒体文件播放的支持。Android里面提供了MediaPlayer类来播放媒体文件,下面来看一下怎样用MediaPlayer对象来播放媒体文件: 一般来说,用MediaPlayer类来播放媒体文件有以下几个步骤:
指点
2019/01/18
2.7K0
使用Android MediaPlayer播放媒体文件
python引入相同和不同(模块)文件夹下py文件的类
从SyncMysqlMongo中引入MongoDBUtil.py和MySQLUtil.py中的两个类(这里的类名和文件名一致)
静谧星空TEL
2022/01/05
8.1K0
python引入相同和不同(模块)文件夹下py文件的类
Redis 的安装和基本使用以及在 Django 项目中的配置和使用
Redis Redis的安装好基本使用 环境 Python 3.6 Django 2.0.7 django-redis 4.9.0 Mac ???Redis坑(传送门) GitHub https://
Autooooooo
2020/11/09
1.4K0
如何使用goGetBucket扫描和发现AWS S3 Bucket
goGetBucket是一款针对AWS S3 Bucket的渗透测试与安全研究工具,在该工具的帮助下,广大研究人员可以快速扫描和发现AWS S3 Bucket。
FB客服
2023/08/08
2540
如何使用goGetBucket扫描和发现AWS S3 Bucket
Python中如何使用os模块和shutil模块处理文件和文件夹
os和shutil都是Python标准库中用于处理文件和文件夹的模块,它们都提供了许多常用的文件和文件夹操作功能,但是它们的使用场景和优势有所不同。
jackcode
2023/05/04
1.1K0
Python中如何使用os模块和shutil模块处理文件和文件夹
如何设置共享文件夹?
比如文档、图片、视频等。小编认识的好多人别说设置共享了,甚至连怎么添加已有的共享资源都不会,快来一起学习下吧!
简单并不简单
2019/07/05
12.7K1
[css] 使用css画文件夹icon和话筒icon
在一些界面上 , 如果每个icon都去找图片还是相当麻烦的 , 直接使用css画出icon就方便的多了 , 下面两个是画的文件夹和话筒的icon
唯一Chat
2021/02/01
1.3K0
[css] 使用css画文件夹icon和话筒icon
点击加载更多

相似问题

如何使用django-storages和亚马逊S3设置Django项目,但使用不同的文件夹存放静态文件和媒体文件?

63

在亚马逊S3和https中使用Django-Storages

10

如何使用django和nginx配置静态和媒体文件?

10

从S3提供Django的静态和媒体文件

32

Django中的静态文件和媒体文件有什么不同?

20
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档