初始Django
一、Django的历史
Django 是从真实世界的应用中成长起来的,它是由堪萨斯(Kansas)州 Lawrence 城中的一个网络开发小组编写的。它诞生于 2003 年秋天,那时 Lawrence Journal-World 报纸的程序员 Adrian Holovaty 和 Simon Willison 开始用 Python 来编写程序。
当时他们的 World Online 小组制作并维护当地的几个新闻站点,并在以新闻界特有的快节奏开发环境中逐渐发展。这些站点包括有 LJWorld.com、Lawrence.com 和 KUsports.com,记者(或管理层) 要求增加的特征或整个程序都能在计划时间内快速的被建立,这些时间通常只有几天或几个小时。因此,Adrian 和 Simon 开发了一种节省时间的网络程序开发框架,这是在截止时间前能完成程序的唯一途径。
2005 年的夏天,当这个框架开发完成时,它已经用来制作了很多个 World Online 的站点。当时 World Online 小组中的 Jacob Kaplan-Moss 决定把这个框架发布为一个开源软件。
从今往后数年,Django是一个有着数以万计的用户和贡献者,在世界广泛传播的完善开源项目。原来的World Online的两个开发者(Adrian and Jacob)仍然掌握着Django,但是其发展方向受社区团队的影响更大。
这些历史都是相关联的,因为她们帮助解释了很重要的两点。
第一,Django最可爱的地方。Django 诞生于新闻网站的环境中,因此它提供很多了特性(如管理后台),非常适合内容类的网站(不要看到这就感到沮丧,尽管Django擅长于动态内容管理系统,但并不表示Django主要的目的就是用来创建动态内容的网站。某些方面特别高效与其他方面不高效是有区别的,Django在其他方面也同样高效。)
第二,Django的起源造就了它的开源社区的文化。因为Django来自于真实世界中的代码,而不是来自于一个科研项目或者商业产品,她主要集中力量来解决Web开发中遇到的问题,同样也是Django的开发者经常遇到的问题。这样,Django每天在现有的基础上进步。框架的开发者对于让开发人员节省时间,编写更加容易维护的程序,同时保证程序运行的效率具有极大的兴趣。无他,开发者动力来源于自己的目标:节省时间,快乐工作。
二、Django介绍
Django是由Python编写的Web框架,遵循 MVC 设计模式。MVC是Model、View、Controller三个单词的简写,分别代表模型、视图、控制器。Django其实也是一个MTV 的设计模式。MTV是Model、Template、View三个单词的简写,分别代表模型、模版、视图。但是在Django中,控制器接受用户输入的部分由框架自行处理,所以 Django 里更关注的是模型(Model)、模板(Template)和视图(Views),称为 MTV模式。
Django 框架的核心组件有:
- 用于创建模型的对象关系映射
- 为最终用户设计较好的管理界面
- URL 设计
- 设计者友好的模板语言
- 缓存系统
三、Django的架构模式
MVC架构模式
mvc是由美国的施乐公司(代表产品是打印机、复印机产业)旗下的帕罗奥多研究中心一位程序员发明了smalltalk语言(第二个面向对象的语言),simula67(第一个面向对象的语言)
MVC的产生理念:分开。专门的人做专门的事(像公司中各部门一样,不同的部门做着不同的事)
MVC的核心思想:解藕。(例如:电脑硬盘坏了,不需要把整个电脑换掉,只需要把硬盘换了,就可以正常使用了。)
MVC是一种使用MVC(Model View Controller 模型-视图-控制器)设计创建 Web 应用程序的模式:
- M为Model(模型), 主要是对数据库的交互,对数据库中的数据进行增删改查操作。
- V为View,主要是用于封装,来生成展示给浏览器的html用户
- C为Controll,主要是用于接受请求,处理业务逻辑,返回结果,与Model和View交互调度
MVT架构模式
Django在处理的过程中,对于经典的MVC处理模式并不是非常认同,在实际项目开发过程中控制器Controller起到的作用非常的有限,所以Django将控制器部分也进行了封装,但是同时扩展了视图View部分,增加了模板功能实现了前端网页的复用,所以Django的架构模式更加符合MVT处理模式
- M:model数据模型
- V:View视图
- T:Template模板
安装Django
一、虚拟环境简介
1、什么是虚拟环境?
虚拟环境是用于依赖项管理和项目隔离的Python工具,允许Python站点包(第三方库)安装在本地特定项目的隔离目录中,而不是全局安装。
2、为什么需要虚拟环境?
我们所有的第三方包安装都是直接通过pip install xx
的方式进行安装的,这样安装会将那个包安装到你的系统级的Python
环境中。但是这样有一个问题,就是如果你现在用Django 2.1.x
写了个网站,然后你的领导跟说,之前有一个旧项目是用Django 1.11.x
开发的,让你来维护,两个版本的django,有些语法上的差异,可能会导致维护旧项目会出问题,这个时候,就可以通过虚拟环境来解决这个问题。
3、常用的虚拟环境
virtualenv、venv、conda
windows下安装virtualenv
pip install virtualenv
pip install virtualenvwrapper-win
virtualenv创建虚拟环境时,目录是创建在C盘下的用户文件夹下,不方便管理,可以通过更改配置,来更改默认创建位置
二、更改虚拟环境默认创建位置
添加环境变量
此电脑–>右键属性–>高级系统设置–>高级–>环境变量–>新建,在弹出的对话框中,输入以下内容
变量名:WORKON_HOME
变量值:d:\myenv
变量值后面跟的是一个文件夹的路径
在python的scripts下,找到mkvirtualenv.bat
修改其中第24行内容
修改红色方框中,=号后面的内容为环境变量中变量值的内容
三、virtualenv使用
-
创建虚拟环境
# mkvirtualenv 环境名 mkvirtualenv my_env
创建好的虚拟环境,默认已经在虚拟环境当中,不需要再次进入
-
进入虚拟环境
# workon 环境名 workon my_env
-
退出虚拟环境
deactivate
-
删除虚拟环境
# rmvirtualenv 环境名 rmvirtualenv my_env
-
列出所有的虚拟环境
lsvirtualenv
-
创建虚拟环境的时候指定
Python
版本mkvirtualenv my_env --python==d:\Program Files\Python39\python.exe
四、安装Django
# 创建虚拟环境
mkvirtualenv mydj32
# 进入虚拟环境
workon mydj32
# 在虚拟环境中不指定版本,直接安装,默认安装最新版
pip install django # [安装最新版本的django, 生产环境当中不适用]
# 安装指定版本的Django
pip install django==3.2.18 # 安装3.2版本当中最新版本
# 如果安装速度慢,可以使用国内镜像安装
pip install django==3.2.18 -i https://pypi.douban.com/simple/
创建项目
1、使用命令创建项目
1)、 使用命令创建项目
# cd 进入到要创建项目的目录下 D:\mycodes\django_code
D:\mycodes\django_code>
# 进入虚拟环境 workon myenv
D:\mycodes\django_code>workon mydj32
(mydj32) D:\mycodes\django_code>
# 使用命令创建项目
(mydj32) D:\mycodes\django_code>django-admin startproject mysite
2)、 项目目录介绍
mysite
__init__.py
asgi.py
settings.py # 项目的整体配置文件
urls.py # 项目的URL配置文件
wsgi.py # 项目与WSGI兼容的Web服务器入口
manage.py # 项目管理文件,通过它管理项目
3)、启动项目
# 启动项目的命令
python manage.py runserver # http://127.0.0.1:8000 默认启动IP和端口
# 批定IP和端口启动项目
python manage.py runserver 192.168.31.100:8080
2、创建子应用
Django的视图编写都在子应用中完成,在web应用中,通常有一些业务功能模块是在不同的项目中都可以复用的,故在开发中通常将工程项目拆分为不同的子功能模块,各功能模块间可以保持相对的独立。
创建app
# 使用命令创建应用 python manage.py startapp app_name
python manage.py startapp equipment
子应用目录文件说明
equipment
migrations # 存放数据库迁移历史文件
__init__.py
admin.py # 网站的后台管理站点配置相关
apps.py # 当前子应用的相关信息
models.py # 用户保存数据库模型类
tests.py # 开发测试用例,编写单元测试
views.py # 编写Web应用视图函数
3、settings.py配置
# 项目所在的目录的根目录
BASE_DIR = Path(__file__).resolve().parent.parent
# 项目创建时生成的密钥
SECRET_KEY = 'django-insecure-8!&bnte&q$2g$a%xfds8)-5^1#@ora4)d**%=n59^@7^v7#1wl'
# 允许连接的主机
ALLOWED_HOSTS = []
# 应用列表
INSTALLED_APPS = [
# 前6项为项目默认的应用
'django.contrib.admin', # django后端管理应用
'django.contrib.auth', # django认证应用
'django.contrib.contenttypes',
'django.contrib.sessions', # django的session应用
'django.contrib.messages', # django的消息应用
'django.contrib.staticfiles', # django的静态文件
# 自建app
'equipment.apps.EquipmentConfig',
]
# 中间件
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 = 'mysite.urls'
# 数据库配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'mysite',
'USER': 'root',
'PASSWORD': 'Root@1234',
'HOST': '127.0.0.1',
'PORT': 3307,
}
}
# 密码验证
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',
},
]
# 语言时区设置
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_L10N = True
USE_TZ = False
# 静态文件路由
STATIC_URL = '/static/'
请求和响应
1、基于模板的第一个Hello World
1. 编写FBV视图
from django.shortcuts import render
# Create your views here.
def index(request):
return render(request, 'equipment/index.html')
2. 编写index.html内容
应用equipment下新建templates文件夹,在templates下新建equipment文件夹,在app同名的目录下新建index.html,写入如下内容:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>第一个Hello World</title>
</head>
<body>
<h1>Hello world!!</h1>
</body>
</html>
3. 配置路由
在应用equipment下新建urls.py文件,配置如下内容:
from django.urls import path # 导入django的path函数
from . import views # 导入应用下的views.py这个文件
app_name = 'equipment' # app的名称
# 路由配置列表
urlpatterns = [
path('', views.index, name='index')
]
4. 配置主路由
from django.contrib import admin
from django.urls import path, include
urlpatterns = [
path('admin/', admin.site.urls),
path('equip/', include('equipment.urls')),
]
5. 访问页面效果展示
2、基于Json的第一个Hello world
1. 编写视图
不指定请求方式的话, 默认为GET请求
from django.http.response import JsonResponse
def index_api(request):
return JsonResponse({
'message': 'success',
'code': 200,
'data': 'Hello World!!'
})
2. 配置路由
from django.urls import path
from . import views
app_name = 'equipment'
urlpatterns = [
path('index_api/', views.index_api),
]
3. json请求效果展示
3、基于CBV的第一个请求
1. 编写请求视图
类视图在编写请求函数时,需要指定请求方式。如: get\post\put\delete\head等
from django.shortcuts import render
from django.views import View
class IndexView(View):
"""
首页
"""
def get(self, request):
return render(request, 'equipment/index.html')
2. 配置路由
from django.urls import path
from . import views
app_name = 'equipment'
urlpatterns = [
path('index/', views.IndexView.as_view()),
]