浅谈Web框架
一,什么是框架?
软件框架就是为实现或完成某种软件开发时,提供了一些基础的软件产品,
框架的功能类似于基础设施,提供并实现最为基础的软件架构和体系
通常情况下我们依据框架来实现更为复杂的业务程序开发
一个字,框架就是程序的骨架
二,框架的优缺点
可重用
成熟,稳健
可扩展性良好
选对框架很重要
三,python中常见的框架
大包大揽 Django
被官方称之为完美主义者的Web框架。
力求精简 web.py
和Tornado
新生代微框架 Flask
和Bottle
MVC设计模式
MVC实现了前后端和数据的分离,程序的解耦合,实现了程序的可扩展性,可维护性
英文 | 中文 | 针对部分 | 作用 |
---|---|---|---|
Model | 模型 | 是针对数据库层面的 | 程序调用模型,直接操作继承model的模型对象 |
View | 视图 | 是针对用户界面的数据显示 | 模板(hmtl) |
Controller | 控制器 | 针对业务逻辑的操作 | python程序 |
MVT
M | Model | 模型 | 数据层 |
V | View | 视图 | 业务逻辑 |
T | Template | 模板 | html |
起步
1. 认识Django
Django是一个高级的Python Web框架,它鼓励快速开发和清洁,务实的设计。
由经验丰富的开发人员构建,它负责Web开发的许多麻烦,因此您可以专注于编写应用程序,而无需重新创建轮子。
它是免费的和开源的。
被官方称之为完美主义者的Web框架。
Django可以更快地构建更好的Web应用程序并减少代码。
官方网址:https://www.djangoproject.com/
中文文档:http://python.usyiyi.cn/
2. Django框架的特点:
快速开发:Django的宗旨在于帮助开发人员快速从概念到完成应用程序。
安全可靠:Django认真对待安全性,帮助开发人员避免许多常见的安全错误。
超可伸缩性: Web上的一些最繁忙的网站利用了Django快速灵活扩展的能力。
3. Django可以使用什么Python版本?
Django版本 | Python版本 |
---|---|
1.8 | 2.7,3.2(直到2016年底),3.3, 3.4, 3.5 |
1.9, 1.10 | 2.7, 3.4, 3.5 |
1.11 | 2.7 , 3.4 , 3.5 , 3.6 |
2.0 | 3.5+ |
4. Django的开发版本
LTS : 长期稳定版
- 2015 April 1.8
- 2017 April 1.11
- 2019 April 2.2
5. Django安装
作为Python Web框架,Django需要Python,在安装Python同时需要安装pip。
# 在线安装Django
pip3 install Django
# 检测当前是否安装Django及版本
python3 -m django --version
1.11.7
这里可以使用 -i 参数来指定镜像源位置
6. 使用Django框架搭建项目
# 在一个目录中执行一下命令,就会创建一个web项目目录
django-admin startproject web
# 进入到web文件夹中,执行以下命令,启动项目
python3 manage.py runserver
# 接下来就可以在浏览器中访问了
Django入门
创建一个应用
python3 manage.py startapp home
# 以上命令会在项目文件夹中创建一个目录home
请求的流程
用户输入url地址发起请求,服务器接受到请求后,交给跟路由(项目同名目录下的urls.py)
使用模板文件
URLconf路由
路由的定义
URL ==> 统一资源定位符
指得就是请求的(URL)地址
http://python.itxdl.cn/html/tutorial/
http://python.itxdl.cn/html/teachers/
可以在项目中指定请求的url地址,来交给对应的试图函数进行解析
路由的特点
路由就是在urls中进行规则的配置
按照从上往下的顺序来执行
如果匹配到,则假装指定的视图函数来执行
如果匹配不到,则抛出404 page not found
路由参数
路由参数就是在定义规则时,使用小括号
()
括起来的内容,将作为参数传递给视图函数
# 路由规则
url(r'^article/(d)$', views.article),
# 视图函数
def article(request,para):
return HttpResponse('接受到的参数是:'+para)
命名组,命名参数
和路由参数一样是用来获取url中路径作为参数来使用
不同的是,命名组会把当前参数作为,关键字参数传递给视图函数,
因此对应的视图函数,必须有关键字参数
# 命名组 使用?P<变量名>方式来定义
url(r'abc/(?P<aa>[0-9]+/$',view.abc_2003)
# 在对应的视图函数中则必须有对应的关键字
def abc_2003(request,aa):
print(aa)
return HttpResponse('abc_2003')
指定用于视图参数的默认值
两个路由指向同一个视图函数
# 路由
url(r'^user/index/(?P<page>[0-9]+)/$', views.user_index),
url(r'^user/index/$', views.user_index),
# 视图函数
def user_index(request,page=1):
print(page)
return HttpResponse('用户列表数据的显示'+page)
Model模型
数据库配置
- 安装mysql
- 创建库,指定字符集
- 安装pymysql
- 在settings.py的同级目录中找到__init__.py文件,声明pymysql
- 在settings.py文件中配置 数据库
- 在settings.py文件中添加当前的应用
定义模型
在模型中定义属性,会生成表中的字段
django会为表增加自动增长的主键列,每个模型只能有一个主键列
如果使用选项设置某属性为主键列后,则django不会再生成默认的主键列
属性命名限制
不能是python的保留关键字
由于django的查询方式,不允许使用连续的下划线
定义步骤
- 找到应用中的models.py文件
from django.db import models
# Create your models here.
# 模型的作用,降低程序的耦合性,更换数据库就改个配置文件就行了
class Users(models.Model):
username = models.CharField(max_length=32)
password = models.CharField(max_length=32)
email = models.CharField(max_length=50)
- 生成迁移文件
python3 manage.py makemigrations
- 执行迁移
python3 manage.py makemigrate
View视图
Django中的视图
Django具有“视图”的概念来封装负责处理用户请求和返回响应的逻辑
视图函数或视图简而言之就是一个Python函数,它接受一个Web请求并返回一个Web响应
此响应可以是网页的HTML内容,重定向或404错误,XML文档或图像。
为了将代码放在某处,惯例是将视图views.py放在名为的文件中,放在项目或应用程序目录中
在视图函数中使用模型
- 先在视图函数中导入models
from . import models
# 模型的操作演示
def mod_demo(request):
# 使用模型进行操作数据库 数据的查询操作
res = models.Users.objects.all()
print(res)
# < QuerySet[ < Users: Users object >] >
# 一个查询集
for x in res:
print(x.username)
return HttpResponse('模型你给的操作演示')
url 统一资源定位符
http://127.0.0.1:8000/user/abc?a=1&b=2
协议:http https file svn
ip或域名 127.0.0.1 www.itxdl.cn
端口: 80 443 8000 5000 8080
路径: /user/abc
参数: ?a=1&b=2
模型的操作
# 1查询
# 获取当前模型中所有的对象数据
# 结果为一个查询集
obs = models.Stu.objects.all()
# 根据id获取当前对象 结果 对象
ob = models.Stu.objects.get(id=1)
# 注意:get方法能且只能返回一个对象
# 查多个报错,查不到也报错
# 2添加
# 第一中方法
data = {'name':'admin','age',20}
ob = models.Stu(**data)
ob.save()
# 第二种方法
ob = models.Stu()
ob.name = 'zhangsan'
ob.age = 20
ob.save()
# 推荐第一种
# 3删除
# 获取对象.执行删除
ob.delete())
# 4更新
ob.name = 'aabb'
ob.save())
增删改查
用户管理
先定义一个视图函数 显示添加表单
表单吧数据提交到 执行数据添加的函数中
完成后跳转到 用户列表的视图函数中
删除链接提交到 一个执行用户删除的视图函数中k,完成后跳转列表页面
编辑链接提交到 一个显示用户数据的修改表单中
修改表单吧数据 提交到执行数据更新的视图函数中
这6个步骤对应6个路由
# 用户数据的管理
url(r'stu/index$',views.stu_index,name='stu_index'),
# 执行用户的添加
url(r'stu/insert$',views.stu_insert,name='stu_insert'),
# 显示添加的表单
url(r'stu/add$',views.stu_add,name='stu_add'),
# 执行用户的删除
url(r'stu/del$',views.stu_del,name='stu_del'),
# 用户的编辑表单
url(r'stu/edit$',views.stu_edit,name='stu_edit'),
# 执行用户数据的更新
url(r'stu/update$',views.stu_update,name='stu_update'),
生成迁移文件时,还没有吧应用添加到配置文件中?
如果已经生成迁移文件,则直接执行迁移就可以,
另外注意,生成的迁移文件不要轻易删除
模型定义
class User(models.Model):
pass
在这里已经说了
模型更改问题
如果模型已经创建好了一个表,你再模型中在增加一个字段,在生成迁移文件的时候就会报出
新增的一个字段时注意,如果当前新增的字段不允许为空,并且没有设置默认值,
则会在生成迁移时
You are trying to add a non-nullable field 'age' to users without a default; we c
an't do that (the database needs something to populate existing rows).
Please select a fix:
1) Provide a one-off default now (will be set on all existing rows with a null v
alue for this column)
2) Quit, and let me add a default in models.py
翻译过来是:
就是说,你加了一个字段,还说不能为空,然后那我之前还有挺多数据呢,这可咋整啊
您还想添加一个非空字段,还没有默认,是不是傻?
选择一个修复吧,赶紧的:
1)提供一个一次性的值
2)退出,修改当前新增字段
1. 设置默认值
2. 允许为空
就算你表中没有数据,他也会这样问,以为他傻,他不知道你有没有数据,他也不能知道,也不需要知道
Django学习中遇到的问题(1)django migration No migrations to apply
Template模板
模板概念
作为Web 框架,Django 需要一种很便利的方法以动态地生成HTML。最常见的做法是使用模板。
模板包含所需HTML 输出的静态部分,以及一些特殊的语法,描述如何将动态内容插入。
模板语法
1.变量
-
变量输出语法
{{ var }}
-
当模版引擎遇到一个变量,将计算这个变量,然后将结果输出
-
变量名必须由字母、数字、下划线(不能以下划线开头)和点组成
-
当模版引擎遇到点("."),会按照下列顺序查询:
- 字典查询,例如:foo[“bar”]
- 属性或方法查询,例如:foo.bar
- 数字索引查询,例如:foo[bar]
-
如果变量不存在, 模版系统将插入’’ (空字符串)
-
在模板中调用方法时不能传递参数
2.标签
- 语法
{ % tag % }
- 作用
- 在输出中创建文本
- 控制循环或逻辑
- 加载外部信息到模板中
for标签
{ % for ... in ... % }
循环逻辑
{ % endfor % }
if标签
{ % if ... % }
逻辑1
{ % elif ... % }
逻辑2
{ % else % }
逻辑3
{ % endif % }
comment标签
{ % comment % }
多行注释
{ % endcomment % }
include:加载模板并以标签内的参数渲染
{ % include "base/index.html" % }
url:反向解析
{ % url 'name' p1 p2 % }
csrf_token:这个标签用于跨站请求伪造保护
{ % csrf_token % }
Django框架自带的后台
-
在浏览器访问 admin
http://127.0.0.1:8000/admin/
-
需要登录,因此要创建一个超级用户
在命令行执行下一个命令进行创建
python3 manage.py createsuperuser
-
重新启动服务后 ,使用创建的用户进行后台的登录
-
配置settings.py文件,配置语言和时区
LANGUAGE_CODE = 'zh-Hans'
TIME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_L10N = True
USE_TZ = False