Django статические файлы - PullRequest
4 голосов
/ 22 марта 2012

Я пытаюсь разработать сайт с Django, следуя различным руководствам, документации и Google. У меня настроены плоские страницы, которым нужен доступ к файлам изображений / CSS.

Мой файл settings.py выглядит так:

# Django settings for FirstBlog project.

DEBUG = True
TEMPLATE_DEBUG = DEBUG

ADMINS = (
    # ('Your Name', 'your_email@example.com'),
)

MANAGERS = ADMINS

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.
        'NAME': 'db',                      # Or path to database file if using sqlite3.
        'USER': '',                      # Not used with sqlite3.
        'PASSWORD': '',                  # Not used with sqlite3.
        'HOST': '',                      # Set to empty string for localhost. Not used with sqlite3.
        'PORT': '',                      # Set to empty string for default. Not used with sqlite3.
    }
}

# Local time zone for this installation. Choices can be found here:
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
# although not all choices may be available on all operating systems.
# On Unix systems, a value of None will cause Django to use the same
# timezone as the operating system.
# If running in a Windows environment this must be set to the same as your
# system time zone.
TIME_ZONE = 'America/Chicago'

# Language code for this installation. All choices can be found here:
# http://www.i18nguy.com/unicode/language-identifiers.html
LANGUAGE_CODE = 'en-us'

SITE_ID = 3

# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
USE_I18N = True

# If you set this to False, Django will not format dates, numbers and
# calendars according to the current locale
USE_L10N = True

# Absolute filesystem path to the directory that will hold user-uploaded files.
# Example: "/home/media/media.lawrence.com/media/"
MEDIA_ROOT = ''

# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash.
# Examples: "http://media.lawrence.com/media/", "http://example.com/media/"
MEDIA_URL = ''

# Absolute path to the directory static files should be collected to.
# Don't put anything in this directory yourself; store your static files
# in apps' "static/" subdirectories and in STATICFILES_DIRS.
# Example: "/home/media/media.lawrence.com/static/"
STATIC_ROOT = '/export/mailgrp4_a/sc10jbr/WWWdev/FirstBlog/djangostatic/'

# URL prefix for static files.
# Example: "http://media.lawrence.com/static/"
STATIC_URL = '/static/'

# URL prefix for admin static files -- CSS, JavaScript and images.
# Make sure to use a trailing slash.
# Examples: "http://foo.com/static/admin/", "/static/admin/".
ADMIN_MEDIA_PREFIX = '/static/admin/'

# Additional locations of static files
STATICFILES_DIRS = (
    '/export/mailgrp4_a/sc10jbr/WWWdev/FirstBlog/static/',
    # Put strings here, like "/home/html/static" or "C:/www/django/static".
    # Always use forward slashes, even on Windows.
    # Don't forget to use absolute paths, not relative paths.
)

# List of finder classes that know how to find static files in
# various locations.
STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
#    'django.contrib.staticfiles.finders.DefaultStorageFinder',
)

# Make this unique, and don't share it with anybody.
SECRET_KEY = 'nc*v+e13e#!b+dq9mh-vwi0smy#r97#by1w7pvc36ez$j%rz1b'

# List of callables that know how to import templates from various sources.
TEMPLATE_LOADERS = (
    'django.template.loaders.filesystem.Loader',
    'django.template.loaders.app_directories.Loader',
#     'django.template.loaders.eggs.Loader',
)

MIDDLEWARE_CLASSES = (
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware',
)

ROOT_URLCONF = 'FirstBlog.urls'

TEMPLATE_DIRS = (
    '/export/mailgrp4_a/sc10jbr/WWWdev/FirstBlog/templates',
    # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
    # Always use forward slashes, even on Windows.
    # Don't forget to use absolute paths, not relative paths.
)

INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'FirstBlog.blog',
    'django.contrib.flatpages',
    # Uncomment the next line to enable the admin:
    'django.contrib.admin',
    # Uncomment the next line to enable admin documentation:
    'django.contrib.admindocs',
)

# A sample logging configuration. The only tangible logging
# performed by this configuration is to send an email to
# the site admins on every HTTP 500 error.
# See http://docs.djangoproject.com/en/dev/topics/logging for
# more details on how to customize your logging configuration.
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'mail_admins': {
            'level': 'ERROR',
            'class': 'django.utils.log.AdminEmailHandler'
        }
    },
    'loggers': {
        'django.request': {
            'handlers': ['mail_admins'],
            'level': 'ERROR',
            'propagate': True,
        },
    }
}

Я поместил свои изображения / CSS-файлы в FirstBlog/static/images и /css. Я выполнил команду

python manage.py collectstatic

, который поместил все мои файлы в FirstBlog/djangostatic.

Я пытаюсь получить доступ к изображению из моей страницы index.html, используя тег:

src="{{ /static/ }}images/header.png"

Я включил эту строку в мой файл urls.py:

url(r'^static/(.*)$', 'django.views.static.serve', {'document_root':settings.STATIC_PATH}),

Это дает мне следующую ошибку:

Name Error at /static

name 'settings' is not defined

Request Method:     GET
Request URL:    http://127.0.0.1:8000/static
Django Version:     1.3.1
Exception Type:     NameError
Exception Value:    

name 'settings' is not defined

Exception Location:     /home/cserv2_a/soc_ug/sc10jbr/WWWdev/FirstBlog/../FirstBlog/urls.py in <module>, line 19

Извините, если это очевидно, я часами смотрел в интернете.

Заранее спасибо

Ответы [ 3 ]

23 голосов
/ 22 марта 2012

Джанго - фантастическая система.Многофункциональный и все же простой, элегантный и чрезвычайно хорошо документированный, с отличными примерами ... для всего, кроме статического контента.Мы боремся с этим на каждом новом проекте Django.Но мы недавно решили это, как мы полагаем, «рекомендуемым» способом.

Ключевым моментом, о котором следует помнить, является то, что Django не хочет напрямую обслуживать статический контент.Он предпочел бы, чтобы вы разгрузили это на основной веб-сервер (такой как Apache).Есть способы заставить Django обслуживать его для вас - и вы можете даже подумать, что это хорошая идея, чтобы все служение выполнялось на одной общей платформе.Но поверьте мне на слово - вы пожалеете об этом позже и захотите, чтобы вы просто следовали рекомендациям Django по этому поводу.

Краткая история:

Эти настройки входят в настройки.py '

Установите STATIC_ROOT на полный путь файловой системы, где вы хотите хранить статический контент.Я рекомендую где-нибудь за пределами ваших обычных каталогов веб-приложений.Помните, что Apache будет обслуживать это напрямую, и вы не хотите открывать проблему безопасности у вас под ногами.

Установить STATIC_ROOT = '/ usr / local / static / MyProject /' # includeкосая черта

Set STATIC_URL = '/ static /' # нет причин слишком увлекаться этим

Set ADMIN_MEDIA_PREFIX = '/ static /admin / '# не забудьте об этом

Убедитесь, что по умолчанию установлено STATICFILES_FINDERS :

STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
    )

И убедитесь, что INSTALLED_APPS настройка включает в себя 'django.contrib.staticfiles'

и убедитесь, что TEMPLATE_CONTEXT_PROCESSORS включает в себя 'django.core.context_processors.static'

---- СЛЕДУЮЩИЙ --

Вы захотите настроить Apache для непосредственного сервера статического контента.Из вашего VirtualHost раздела добавьте что-то вроде этого:

Alias /static/  /usr/local/static/MyProject/

ПРИМЕЧАНИЕ: замените путь выше тем же путем, который вы использовали при установке STATIC_ROOT

---- СЛЕДУЮЩИЙ ----

В каждой папке приложения все, что вы хотите добавить в свой STATIC_ROOT , собирает в подпапку с именем «static /»,Например, если у вас было приложение под названием «контроллер», у вас должен быть путь, который выглядит как «контроллер / статический»

Затем в верхней части папки проекта Django выполните подкоманду «collectstatic»из manage.py.Обычно мы создаем сценарий и запускаем его следующим образом:

#!/usr/bin/sh
# Scrtipt to collect django static files together.
#
# --link    Create a symbolic link to each file instead of copying.
# --noinput Do NOT prompt the user for input of any kind.
#
python manage.py collectstatic -link --noinput
exit 0

Вот и все

Вам НЕ нужно вводить какие-либо записи в urls.py - Django никогда не увидит эти запросы,так что нет смысла добавлять записи маршрутизации.

Недостатки

Один большой недостаток подхода, описанного выше, он побеждает использование приложения тест-сервера Django.Мы никогда не используем это для какой-либо работы, и, поскольку наш конечный результат всегда будет публиковаться в Apache, мы считаем, что лучше развиваться только там.Если вы полагаетесь на «testserver» - есть способы обойти это ограничение.Но вам нужно немного покопаться в документации Django https://docs.djangoproject.com/en/dev/howto/static-files/

Удачи

1 голос
/ 22 марта 2012

Пожалуйста, проверьте, импортирован ли модуль настроек в urls.py

0 голосов
/ 22 марта 2012

Добавить в начало urls.py

из настроек импорта django.conf

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...