天天看點

Django知識點:認識Django

web開發

1.web全球廣域網,網際網路,給使用者提供可視化頁面

  • web前端開發:是對頁面的開發,為了給使用者提供更好的頁面
  • web後端開發:給頁面提供資料支援,處理使用者的請求,處理使用者的業務邏輯
    • request:使用者發起的請求
    • response:響應,伺服器處理,構造的響應
    • url:資源在伺服器上的位置
    • 視圖views:處理請求的地方,可以是函數,也可以是類方法

2.域名規則

https://www.baidu.com/

  • https 協定 http
  • 域名:代表伺服器的根目錄
  • 路徑
  • 檔案名,資源的名稱

Django的簡介

1.簡介

python 架構的一種,完成了對同一類代碼的封裝

2. 優點

重量級的架構,提供豐富的功能元件,讓開發邊的簡單,快捷,開發效率快

3. 缺點

開發不夠靈活,不夠自由,不能勝任高度定制開發任務,執行速度相對慢

Django環境的安裝

  1. 如何選擇虛拟環境

    anaconda:不需要安裝python,在建立虛拟環境的時候可以選擇python版本。解決包用來關系的問題。(python3.5.2 + django2.2.1 + anaconda)

    • 安裝-在指令視窗下執行:

      建立環境:conda create -n 虛拟環境的名字 python=3.5.2

      激活虛拟環境:activate DjangoPath(虛拟環境的名字)

      安裝Django:pip install django==2.2.1

      測試django是否安裝成功

      進入python環境:python

      導包:import django

      檢視django版本号:django.VERSION # 如果出現django的版本資訊則說明安裝成功

      退出python環境:exit()

    virtualenv:
    安裝python
    virtualenvwarpper
    workon 虛拟環境的名字
    makevirtualenv 虛拟環境的名字
               
  2. 建立工程并啟動工程
    • 建立一個project 檔案夾,打開進入這個檔案夾,在目錄下執行cmd 進入DOC視窗
    • 激活虛拟環境:activate DjangoPath
    • 建立一個demo的工程:django-admin startproject demo(工程名)
  3. 啟動服務
    • 在自己的主機啟動

      python manage.py runserver

    • 指定主機和指定端口号

      python manage.py runserver 127.0.0.1:9000

    • 任何主機和端口号都可以通路

      python manage.py runserver 0.0.0.0:8000

      這一步需要修改settings 中的配置資訊

    • 啟動的服務是使用django自帶的一個伺服器,輕量,友善使用,最高并發量 200 ,經常用來做開發測試
  4. pycharm 打開項目
    • 第一次打開的工程的時候需要選擇編譯環境,這裡選擇Anaconda3

      Anaconda\envs\DjangoPath\python.exe

      Django知識點:認識Django
      Django知識點:認識Django
    • pycharm啟動服務
      Django知識點:認識Django
  5. 工程目錄介紹
    Django知識點:認識Django
    |-Demo     項目工程目錄
    	|-Demo    項目的主目錄
    		|- __init__.py   項目初始化檔案 
    		|- settings.py   項目的配置檔案
    		|_ urls.py       項目的路由檔案
    		|- wsgi.py       項目的部署服務檔案
    	|- db.sqllit3        資料庫
    	|- manage.py         項目的管理檔案,負責:啟動項目,資料遷移
               
  6. 配置檔案的介紹,相關配置資訊解釋已經在注釋當中說明
"""
Django settings for Demo project.

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

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

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

import os

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
# 項目的根目錄,友善開發人員使用
# os.path.abspath  絕對路徑
# os.path.dirname  檔案所在目錄
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
# print(BASE_DIR)
#

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

# SECURITY WARNING: keep the secret key used in production secret!
## 秘鑰
# SECRET_KEY = '#0^_--5gljl*@sp!x8grz*whz@@%-rqd!wan8rdzx6_$qx_afk'
SECRET_KEY = 'fdsfds111'

# SECURITY WARNING: don't run with debug turned on in production!
## 調試模式
## True 開啟調試模式
## 開啟調試模式: 1.更改django代碼,自動重新開機服務   2. 顯示錯誤資訊,請求資訊
DEBUG = True

# 允許通路的主機
ALLOWED_HOSTS = ['*']


# Application definition
## 注冊app的   注冊子應用
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

## 中間件  中間人
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

## 路由的根目錄
ROOT_URLCONF = 'Demo.urls'

### 模闆的配置
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        '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',
            ],
        },
    },
]

## django内置伺服器
WSGI_APPLICATION = 'Demo.wsgi.application'


# Database
# https://docs.djangoproject.com/en/2.2/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/2.2/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/2.2/topics/i18n/

## 語言
# LANGUAGE_CODE = 'en-us'
LANGUAGE_CODE = 'zh-hans'
## 時區
# TIME_ZONE = 'UTC'
TIME_ZONE = 'Asia/Shanghai'   ## 上海時區

## 翻譯系統 
USE_I18N = True
## 資料本地化配置
USE_L10N = True
## 是否使用指定的時區
## True 使用django 預設時區   内置時區
## Flase 使用指定的時區
USE_TZ = True


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

## 靜态檔案的配置
STATIC_URL = '/static/'


           
  1. 全局配置檔案的目錄
    Django知識點:認識Django

設計模式

  1. django是一個MVT設計模式,同時遵循MVC模式

    MVC子產品的核心宗旨就是:解耦,模型的複用,讓不同的代碼之間的耦合度降低,增強代碼的擴充性和可移植性還有友善 維護,模型不用關心處理結果展現,比如模型傳回一些資料,然後交給不用的視圖展現,可以使用不同的視圖來通路同一個模型。友善測試, 比如,将業務邏輯代碼寫在servlet裡面,需要部署到容器上,然後才能測試。而将業務邏輯代碼寫在類裡面,可以直接用main()測試(不依賴容器)。

    MVC

    Django知識點:認識Django
    • M:全拼為Model(子產品),主要封裝對資料庫層的通路, 資料處理,對資料庫中的資料進行增、删、改、查操作。
    • V:全拼為View(視圖),界面顯示,用于封裝結果,生成頁面展示的html内容。
    • C:全拼為Controller(控制器),邏輯處理,用于接收請求,處理業務邏輯,與Model和View互動,傳回結果。

      MVT

      Django知識點:認識Django
    • M:全拼為Model(子產品),主要封裝對資料庫層的通路, 資料處理,對資料庫中的資料進行增、删、改、查操作。
    • V:和MVC 的C相似,接收和處理請求,處理業務邏輯,和Model,Views互動,傳回結果
    • T:和MVC 中的V相似,界面顯示,封裝結果,提供html頁面支援

繼續閱讀