2016-07-05 12 views
2

私の静的ファイル(css、jsなど)を私のdjangoプロジェクトにインポートしようとしています。しかし、何をしようとしていてもエラー500と表示されます。 私はすでに公式の文書https://docs.djangoproject.com/en/1.9/howto/static-files/を読んでいますが、問題は見えません。 テンプレートの読み込みがうまくいくように見えるのは私にとって気になることです。Djangoの静的ファイルがロードされていません

デベロッパーコンソールに表示されているGETリクエストも正当であるようです(例:http://127.0.0.1:8000/static/css/custom.css)。ここでcustom.cssは/project_folder/static/css/custom.cssにあります。

マイフォルダ構造:

myproject 
-> static 
-->css 
--->custom.css 
-> templates 
-->base.html(where i request the static file) 
-> myproject(app) 
-->settings.oy 
-->urls.py 
-> data_handler(app) 
-->static 

..

ここでは私のsettings.pyです:

""" 
Django settings for myproject project. 

Generated by 'django-admin startproject' using Django 1.9.7. 

For more information on this file, see 
https://docs.djangoproject.com/en/1.9/topics/settings/ 

For the full list of settings and their values, see 
https://docs.djangoproject.com/en/1.9/ref/settings/ 
""" 

import os 

# Build paths inside the project like this: os.path.join(BASE_DIR, ...) 
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) 


# Quick-start development settings - unsuitable for production 
# See https://docs.djangoproject.com/en/1.9/howto/deployment/checklist/ 

# SECURITY WARNING: don't run with debug turned on in production! 
DEBUG = True 

ALLOWED_HOSTS = [] 


# Application definition 

INSTALLED_APPS = [ 
    'rest_framework', 
    'django.contrib.admin', 
    'django.contrib.auth', 
    'django.contrib.contenttypes', 
    'django.contrib.sessions', 
    'django.contrib.messages', 
    'django.contrib.staticfiles', 
    'myproject', 
    'info_pages', 
    'data_handler', 
] 

MIDDLEWARE_CLASSES = [ 
    'django.middleware.security.SecurityMiddleware', 
    'django.contrib.sessions.middleware.SessionMiddleware', 
    'django.middleware.common.CommonMiddleware', 
    'django.middleware.csrf.CsrfViewMiddleware', 
    'django.contrib.auth.middleware.AuthenticationMiddleware', 
    'django.contrib.auth.middleware.SessionAuthenticationMiddleware', 
    'django.contrib.messages.middleware.MessageMiddleware', 
    'django.middleware.clickjacking.XFrameOptionsMiddleware', 
] 

ROOT_URLCONF = 'myproject.urls' 

TEMPLATES = [ 
    { 
     'BACKEND': 'django.template.backends.django.DjangoTemplates', 
     'DIRS': [os.path.join(BASE_DIR, 'templates')], 
     'APP_DIRS': True, 
     'OPTIONS': { 
      'context_processors': [ 
       'django.template.context_processors.debug', 
       'django.template.context_processors.request', 
       'django.contrib.auth.context_processors.auth', 
       'django.contrib.messages.context_processors.messages', 
      ], 
     }, 
    }, 
] 

WSGI_APPLICATION = 'myproject.wsgi.application' 


# Database 
# https://docs.djangoproject.com/en/1.9/ref/settings/#databases 

DATABASES = { 
    'default': { 
     'ENGINE': 'django.db.backends.sqlite3', 
     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), 
    } 
} 


# Password validation 
# https://docs.djangoproject.com/en/1.9/ref/settings/#auth-password-validators 

AUTH_PASSWORD_VALIDATORS = [ 
    { 
     'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', 
    }, 
    { 
     'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', 
    }, 
    { 
     'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', 
    }, 
    { 
     'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', 
    }, 
] 


# Internationalization 
# https://docs.djangoproject.com/en/1.9/topics/i18n/ 

LANGUAGE_CODE = 'en-us' 

TIME_ZONE = 'UTC' 

USE_I18N = True 

USE_L10N = True 

USE_TZ = True 


# Static files (CSS, JavaScript, Images) 
# https://docs.djangoproject.com/en/1.9/howto/static-files/ 


STATICFILES_DIRS = ( 
    os.path.join(BASE_DIR,'static/'), 
    os.path.join(BASE_DIR,'data_handler/static/'), 
    os.path.join(BASE_DIR,'myproject/static/'), 
    ) 

STATIC_URL = '/static/' 
STATIC_ROOT= os.path.join(BASE_DIR,'static/') 

MEDIA_URL = '/media/' 
MEDIA_ROOT = os.path.join(BASE_DIR, 'media') 

私は静的ファイルをインポートbase.html:

{% load staticfiles %} 
<!DOCTYPE html> 

<head> 
    <meta name="generator" content= 
    "HTML Tidy for HTML5 (experimental) for Mac OS X https://github.com/w3c/tidy-html5/tree/c63cc39"> 
    <meta charset="utf-8"> 
    <meta http-equiv="X-UA-Compatible" content="IE=edge"> 
    <meta name="viewport" content="width=device-width, initial-scale=1"> 

    <title>SMGR: Slime Mold Graph Repository</title> 
    <link href="{% static "css/bootstrap.min.css" %}" rel="stylesheet"> 
    <link href="{% static "css/sticky_footer.css" %}" rel="stylesheet"> 
    <link href="{% static "css/custom.css" %}" rel="stylesheet"> 
    <link href="{% static "css/expandy.css" %}" rel="stylesheet"> 
    <link rel="shortcut icon" type="image/png" href="{% static "favicon/favicon.ico" %}"/> 
    <script src="//code.jquery.com/jquery-1.11.1.min.js"></script> 
</head> 

<body> 
    {% block content %} 
    {% endblock content %} 
<div class="spacer-huge"/> 
</body> 

<footer class="footer" style="left:0px;"> 
    <div class="container" style="margin-top:9px"> 
    <a href="http://www.mpi-inf.mpg.de/departments/algorithms-complexity/"> 
     <img src="{% static "images/mpilogo-inf-wide.png" %}" alt="mpi logo"></a> 
    <div style="float:right"> 
     <p class="small"> 
     <a href="http://www.mpi-inf.mpg.de/imprint/" style="font-size:large;">Imprint</a> 
     </p> 
    </div> 
    </div> 
</footer> 
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"> 
</script> <!-- Include all compiled plugins (below), or include individual files as needed --> 
    <script src="{% static "js/bootstrap.min.js" %}"> 
</script> 
+0

また、urlをr​​oot urls.pyに追加する必要があります。これをチェックしてくださいhttps://docs.djangoproject.com/en/1.9/howto/static-files/#serving-static-files-during-development –

+0

@RajeshYogeshwarは正しいです、ちょっと詳細です。 DEBUG = Trueであり、あなたの場合です。それは生産の別の方法です – Bestasttung

+0

ありがとう!私はsettings.pyを変更しました。私はstaticfiles_dirsをハードコードしていますので、urls.pyに特別な努力をする必要はありません。 – gdenn

答えて

4

django 1.9を使用していますそれをする2つの方法。 DEBUG = Trueの場合は、サーバをエミュレートするのはあなたのrunserverですが、静的なものを提供する必要があります。 だから、行うことができます:あなたのアプリで

  • 使用django.contrib.staticfilesを、そして(リスト内の)良い静的dirとURLを設定します。
  • あなたのプロジェクトは、あなたがthisを行う必要があります実サーバによって提供されますときだけ

    from django.conf import settings 
    from django.conf.urls.static import static 
    
    urlpatterns = [ 
        # ... the rest of your URLconf goes here ... 
    ] + static(settings.STATIC_URL, document_root=settings.STATIC_ROOT) 
    

のようなあなたのルートURLのファイルでそれらを提供しています。

+0

これは私のDjango 1.11で動作しました – Phares

関連する問題