Python_Django-1

一.基本配置

  1. 創建項目
    • 終端命令:django-admin startproject sitename
    • IDE自動創建Django程序

其他常用命令:
  python manage.py runserver 0.0.0.0
  python manage.py startapp appname
  python manage.py syncdb
  python manage.py makemigrations
  python manage.py migrate
  python manage.py createsuperuser
  
2. 程序目錄

這裏寫圖片描述
3. 配置文件
  1.數據庫

  DATABASES = {
    'default': {
    'ENGINE': 'django.db.backends.mysql',
    'NAME':'dbname',
    'USER': 'root',
    'PASSWORD': 'xxx',
    'HOST': '',
    'PORT': '',
    }
}
## 由於Django內部連接MySQL時使用的是MySQLdb模塊,而python3中還無此#模塊,所以需要使用pymysql來代替

## 如下設置放置的與project同名的配置的 __init__.py文件中

# import pymysql
# pymysql.install_as_MySQLdb() 

  2.模板

TEMPLATE_DIRS = (
        os.path.join(BASE_DIR,'templates'),
    )

  3.靜態文件

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

二.路由系統

1.單一路由對應

url(r'^index$', views.index),

2.基於正則的路由

url(r'^index/(\d*)', views.index),
url(r'^manage/(?P<name>\w*)/(?P<id>\d*)', views.manage),

3.添加額外的參數

url(r'^manage/(?P<name>\w*)', views.manage,{'id':333}),

4.爲路由映射設置名稱

url(r'^home', views.home, name='h1'),
url(r'^index/(\d*)', views.index, name='h2'),

5.根據app對路由規則進行分類

url(r'^web/',include('app01.urls')),

6.命名空間
Django_url調度器

模板

模板語言
模板中也有自己的語言,該語言可以實現數據展示

  • {{ item }}
  • {% for item in item_list %} <a>{{ item }}</a> {% endfor %}
      forloop.counter
      forloop.first
      forloop.last
  • {% if ordered_warranty %} {% else %} {% endif %}
  • 母板:{% block title %}{% endblock %}
  • 子板:{% extends “base.html” %}
       {% block title %}{% endblock %}
  • 幫助方法:
    {{ item.event_start|date:”Y-m-d H:i:s”}}
    {{ bio|truncatewords:”30” }}
    {{ my_list|first|upper }}
    {{ name|lower }}

中間件

django 中的中間件(middleware),在django中,中間件其實就是一個類,在請求到來和結束後,django會根據自己的規則在合適的時機執行中間件中相應的方法。

在django項目的settings模塊中,有一個 MIDDLEWARE_CLASSES 變量,其中每一個元素就是一箇中間件,如下圖。

與mange.py在同一目錄下的文件夾 wupeiqi/middleware下的auth.py文件中的Authentication類

中間件中可以定義四個方法,分別是:

process_request(self,request)
process_view(self, request, callback, callback_args, callback_kwargs)
process_template_response(self,request,response)
process_exception(self, request, exception)
process_response(self, request, response)
以上方法的返回值可以是None和HttpResonse對象,如果是None,則繼續按照django定義的規則向下執行,如果是HttpResonse對象,則直接將該對象返回給用戶。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章