Django基础全套
1.1 了解web程序工作流程
1.2 Django生命周期
2 Django介绍
-
作用:
- 简便,快速的开发数据库驱动的网站
-
Django框架
1.重量级的框架
2.提供项目工程管理的自动化脚本工具
3.数据库ORM支持(对象关系映射,英语:Object Relational Mapping)
4.模板
5.表单
6.Admin管理站点
7.文件管理
8.认证权限
9.session机制
10.缓存 -
Flask框架
1.轻量型的框架
2.自由、灵活,可扩展性强,第三方库的选择面广,开发时可以结合自己最喜欢用的轮子,也能结合最流行最强大的 Python 库
3 Django设计模式(MVC/MVT)
-
为什么要设计模式
1.分工、解耦,让不同的代码块之间降低耦合,增强代码的可扩展性和可移植性,实现向后兼容。 -
MVC:
M全拼为Model,主要封装对数据库层的访问,对数据库中的数据进行增、删、改、查操作。
V全拼为View,用于封装结果,生成页面展示的html内容。
C全拼为Controller,用于接收请求,处理业务逻辑,与Model和View交互,返回结果。 -
MVT:
M全拼为Model,与MVC中的M功能相同,负责和数据库交互,进行数据处理。
V全拼为View,与MVC中的C功能相同,接收请求,进行业务处理,返回应答。
T全拼为Template,与MVC中的V功能相同,负责封装构造要返回的html。
4 虚拟环境安装
- win10安装
# 方法1:win10
pip install virtualenv
pip install virtualenvwrapper-win
- linux安装
# 方法2:linux pip3 install virtualenvwrapper
mkdir $HOME/.virtualenvs # 把所有虚拟环境指定到一个目 录文件夹下存放
find / -name virtualenvwrapper.sh # 查找执行脚本路径,添加到 ~/.bashrc
vim ~/.bashrc # 修改bash配置文件
``
export WORKON_HOME=$HOME/.virtualenvs VIRTUALENVWRAPPER_PYTHON=/usr/local/bin/python3 source /usr/local/bin/virtualenvwrapper.sh
``
source ~/.bashrc # 执行virtualenvwrapper安 装脚本
- virtualenvwrapper使用命令
mkvirtualenv test1 # 创建虚拟环境
mkvirtualenv test2env -p python3 lsvirtualenv # 查看虚拟环境
workon test1 # 进入虚拟环境
deactivate # 退出虚拟环境
rmvirtualenv test1 # 删除虚拟环境
pip list # 查看虚拟环境下的安装包
- pip命令基本使用
pip pip install # 安装依赖包
pip uninstall # 卸载依赖包
pip list # 查看已经安装的依赖包
pip freeze > requirements.txt # 导出依赖包
pip install -r requirements.txt # 从文件安装依赖包
5.创建项目
目的:能够通过django的命令创建工程
过程:
- 进入到虚拟环境
- 创建项目: django-admin startproject (项目名字)
- 进入到manage.py 所在的文件夹
- 启动项目:python manage.py runserver
注意点:
- 如果不指定,django默认端口8000
- 也可以指定:python manage.py runserver ip:port
6.创建字应用
目的:能够使用django中的命令来创建子应用
过程:
1.进入到manage.py所在的同级文件夹
2.创建子应用: python manage.py startapp (子应用名称)
三步完成子应用创建:
1.注册子应用
- 在settings.py文件, INSTALLED_APP列表中增加"app名字.apps.app的管理类"
2.创建app下的urls文件
- 写子应用的路由文件, 在子应用目录下, 创建 urls文件, 内容拷贝 主路由的内容
3.引入子路由
- 把子路由引入到主路由中, 主路由中添加
7.第一个helloworld程序
- 目的:能够在子应用中编写视图函数helloworld
- 过程:
1.在views文件中编写视图函数
from django.http import HttpResponse
def hello(request):
return HttpResponse('hello world')
2.创建urls.py文件中编写子应用路由
from django.conf.urls import url
from demoapp import views
urlpatterns = [
url(r'^helloworld/$', views.hello),
]
3.将子应用的的路由,注册到根应用的urls中
from django.conf.urls import url, include
from django.contrib import admin
urlpatterns = [
url(r'^demoapp/', include('demoapp.urls'))
]
- 注意点:
- 只要提供了子应用路径,django不再提供默认的根路径
8.项目的配置(settings.py文件)
9.静态资源问题(理解)
- 目的:在django中如何配置静态文件的访问地址和文件夹
- 配置:
- STATIC_URL:静态资源的访问路径,默认是/static/
- STATICFILES_DIRS:静态资源的文件夹,并且是一个列表。 - 注意点:
- STATICFILES_DIRS:是一个列表,寻找文件的时候,从前向后依次寻找,找不到报404错误
10.地址匹配
- 目的:在浏览器访问服务器的时候,根应用的地址,子应用的地址是如何进行匹配的
- 格式1:基本匹配, 从上到下
- 格式2:匹配混乱问题, 有路由覆盖的问题, 建议用path方法
- 格式3:
- 子应用地址后面的 / 问题, 建议大家写的时候都加上
url(r'^index/$', index)
- 在访问的时候,浏览器自动会定向到带有/的地址上面去,这样在访问的时候不管是否携带/,
都能访问。
11.路由参数名设置
- 目的:能够在地址中编写正则匹配
- 过程:
- 1.格式1:不指定正则匹配的名字:/hello/([a-z]+)/(\d+)
- 按照顺序依次匹配,传递参数
- 2.格式2:指定正则的名字:/hello/(?P[a-z]+)/(?P\d+)
- 按照名字来匹配,传递参数
12.get请求
- 目的:通过request对象,获取查询参数
- 过程:
- http://xxx.com/index/?name=xxx&age=ccc&name=yyy request.GET:是一个查询字典
- request.GET.get(key) # 获取单个key,value
- request.GET.getlist(key) # 获取单个key,对应的多个value,得到的是list列表。
13.post,put,delete
- 目的:获取request获取表单,及非表单提交的非查询参数数据
- 常见的请求方式有:POST,PUT,DELETE,PATCH
- 请求体中的数据, 一类是json, 一类是表单数据
- request.POST:获取表单数据(会把body的内容,解析一份, 解析成一个查询字典)
- request.body:获取json数据
- 需要将bytes类型转成dict格式,用到decode(),loads()
# 1.拿到bodyjson数据
body_json = request.body.decode()
# 2. 解析json数据
body_dict = json.loads(body_data)
- Post, put都需要处理请求体, delete可以没有请求体
- post, 通过请求头中的content-type字段来区分格式
- 表单格式: name=zhangsan&age=18
- json格式: '{"name":"zhangsan", "age":18}'
POST http://localhost:8000/app1/post/
Content-Type: application/x-www-form-urlencoded
name=lisi&age=18
###
POST http://localhost:8000/app1/post/
Content-Type: application/json
{"name":"lisi","age": 18}
注意:
json格式需要 decode()