Django - загрузка медиа [Errno 13] В доступе отказано - PullRequest
9 голосов
/ 04 апреля 2011

У меня возникли проблемы с тем, чтобы Django хорошо играл с загрузкой изображений.Мой сценарий будет создавать каталоги на основе даты, например, так:

file = models.FileField(upload_to='uploads/%m-%Y/')

Теперь, если я создаю каталог с датами в папке загрузки и chmod в папку 755, загрузка работает нормально, но если я пытаюсьchmod папка загрузки без создания устаревшей подпапки (что мне нужно сделать для django), я получаю ошибку прав доступа.

Как мне сделать так, чтобы папка позволяла создавать подпапки?

Вот обратная связь:

Django Version: 1.3
Python Version: 2.5.2
Installed Applications:
['django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.admin',
 'tagging',
 'mediamanager',
 'livesettings',
 'projects']
Installed Middleware:
('django.middleware.common.CommonMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware')


Traceback:
File "/var/lib/python-support/python2.5/django/core/handlers/base.py" in get_response
  111.                         response = callback(request, *callback_args, **callback_kwargs)
File "/var/lib/python-support/python2.5/django/utils/decorators.py" in _wrapped_view
  93.                     response = view_func(request, *args, **kwargs)
File "/var/lib/python-support/python2.5/django/contrib/auth/decorators.py" in _wrapped_view
  23.                 return view_func(request, *args, **kwargs)
File "/var/www/enigma-dev/enigma/mediamanager/views.py" in upload_media
  24.           m.upload_media(data=form.cleaned_data, params=params)
File "/var/www/enigma-dev/enigma/mediamanager/models.py" in upload_media
  63.       self.save()
File "/var/lib/python-support/python2.5/django/db/models/base.py" in save
  460.         self.save_base(using=using, force_insert=force_insert, force_update=force_update)
File "/var/lib/python-support/python2.5/django/db/models/base.py" in save_base
  543.                         for f in meta.local_fields if not isinstance(f, AutoField)]
File "/var/lib/python-support/python2.5/django/db/models/fields/files.py" in pre_save
  255.             file.save(file.name, file, save=False)
File "/var/lib/python-support/python2.5/django/db/models/fields/files.py" in save
  92.         self.name = self.storage.save(name, content)
File "/var/lib/python-support/python2.5/django/core/files/storage.py" in save
  49.         name = self._save(name, content)
File "/var/lib/python-support/python2.5/django/core/files/storage.py" in _save
  166.             os.makedirs(directory)
File "/usr/lib/python2.5/os.py" in makedirs
  171.     mkdir(name, mode)

Exception Type: OSError at /media-manager/upload/
Exception Value: [Errno 13] Permission denied: '/var/www/site-dev/site/static/uploads/04-2011'

Ответы [ 2 ]

20 голосов
/ 05 апреля 2011

Процесс, который запускает ваш интерпретатор Python, не имеет разрешения на запись в каталог мультимедиа.Вам потребуется либо chgrp, либо chown каталог мультимедиа в той же группе, что и процесс Python, и убедиться, что у вас есть как минимум g+rwx для каталогов и g+rw для файлов.

9 голосов
/ 08 июля 2015

Я получил ту же ошибку и исправил ее, изменив:

MEDIA_ROOT = '/media/'

на:

MEDIA_ROOT = 'media/'

Под settings.py.

...