2016-07-05 181 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

您還需要在根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你有兩種方式。 由於您在DEBUG = True中,它是模擬服務器的runserver,但您需要爲靜態服務。 所以,你可以這樣做:

  • 使用django.contrib.staticfiles在您的應用程序,並設置好靜態目錄和URL(在列表中)。
  • 爲他們服務在你的根URL文件就像

    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) 
    

當你的項目將由你需要做this一個真正的服務器來提供服務。

+0

這適用於我的Django 1.11 – Phares