Django介绍
-
作用:
便捷,快速的开发数据库驱动的网站 -
Django 的优势
1.快速开发
2.MVT
3.功能齐全 -
思考:
1.开发数据驱动web网站
2.数据分析后的结果展示界面,flask
3.快速成型应用上线,就用django -
HTTP是长成这个样子的
-
- HTTP请求方式:
- HTTP/1.1协议中共定义了八种方法(有时也叫“动作”),来表明Request-URL指定的资源不同的操作方式
- HTTP/1.0定义了三种请求方法:GET,POST和HEAD方法。
- HTTP/1.1新增了五种请求方法:OPIONS,PUT,DELETE,TRACE和CONMECT方法
- HTTP响应状态码
- 1xx 信息 接收请求,继续处理
- 2xx 成功 操作成功的收到,理解和接受
- 3xx 重定向 为了完成请求,必须采取进一步措施
- 4xx 客户端错误 请求的语法有错误,或不能完全被接收
- 5xx 服务器错误 服务器不能完成有效的请求
-
Django设计模型
- 为什么要用设计模式
- 分工、解耦,让不同的的代码块之间降低耦合,增强代码的可扩展性和可移植性,实现向后兼容
-
MVC
1.M全拼为Model,主要封装对数据库层的访问,对数据库中的数据进行增、删、改、查操作。
2.V全拼为View,用于封装结果,生成页面展示的html内容。
3.C全拼为Controller,用于接收请求,处理业务逻辑,与Model和View交互,返回结果。 -
MVT
1.M全拼为Model,与MVC中的M功能相同,负责和数据库交互,进行数据处理。
2.V全拼为View,与MVC中的C功能相同,接收请求,进行业务处理,返回应答。
3.T全拼为Template,与MVC中的V功能相同,负责封装构造要返回的html( 或者是json数据 )
虚拟环境的安装
- 目的:学会创建虚拟环境
- win10安装
1 .方法1
pip install virtualenv
pip install virtualenvwrapper-win
- linux安装
方法2:linux pip3 install virtualenvwrapper
#python版本管理工具(虚拟环 境管理)
mkdir $HOME/.virtualenvs
#把所有虚拟环境指定到一个目 录文件夹下存放 find / -name virtualenvwrapper.sh
#查找执行脚本路径,添加到 ~/.bashrc
vim ~/.bashrc
#修改bash配置文件
''' export WORKON_HOME=$HOME/.virtualenvs
python虚拟环境安装位置 VIRTUALENVWRAPPER_PYTHON=/usr/local/bin/python3
# python真实环境 source /usr/local/bin/virtualenvwrapper.sh '''
source ~/.bashrc
#执行virtualenvwrapper安 装脚本
- virtualenvwrapper使用命令
mkvirtualenv test1 创建虚拟环境
mkvirtualenv test2env -p python3 lsvirtualenv 查看虚拟环境
workon test1 进入虚拟环境
deactivate 退出虚拟环境
rmvirtualenv test1 删除虚拟环境
pip list 查看虚拟环境下的安装包
创建子应用
- 目的:能够使用django中的命令来创建子应用。
- 过程:
1.进入到manage.py所在的同级文件夹。
在settings.py文件, INSTALLED_APP列表中增加"app名 字.apps.app的管理类"
2.创建app下的urls文件。
写子应用的路由文件, 在子应用目录下, 创建 urls文件, 内容拷贝 主路由的内容
3.引入子路由
把子路由引入到主路由中, 主路由中添加
url(r’^子路由前缀’, include(‘子应用的模块名.urls’))
第一个helloworld程序(掌握)
- 目的:能够在子应用中编写视图函数helloworld
- 过程:
1.在views文件中编写视图函数
def hello(request):
return http.HttpResponse('hello world')
2.创建urls.py文件中编写子应用路由。
from django.conf.urls import url, include
from django.contrib import admin
urlpatterns = [
...
url(r'^demoapp/', include('demoapp.urls')) ]
项目的配置(settings.py文件)(理解)
- 目的:知道常见的配置作用即可
- 常见的配置有:
1.BASE_DIR:项目在操作系统中的绝对路径
2.DEBUG:调试模式,默认是True
3.LANGUAGE_CODE: zh-hans中文
4.TIME_ZONE: Asia/Shanghai 中国时间
LANGUAGE_CODE = 'en-us'
zh-hans USE_I18N = True 国际化, 多语言
TIME_ZONE = 'UTC' Asia/Shanghai
USE_L10N = True 时间相关, 时间显示格式, 中文时间格式 xxxx年xx月xx日 21:21:21
USE_TZ = True 时间相关, 使用时区时间, 如果发现时间差8个小时,就查看这个配置
get请求
- 目的:通过request对象,获取查询参数
- 过程:
1.http://xxx.com/index/?name=xxx&age=ccc&name=yyy
2.request.GET:是一个查询字典
3.request.GET.get(key) # 获取单个key,value
4.request.GET.getlist(key) # 获取单个key,对应的多个value,得到的是list列表。
post,put,delete
-
目的:获取request获取表单,及非表单提交的非查询参数数据
-
常见的请求方式有:POST,PUT,DELETE,PATCH
1.请求体中的数据, 一类是json, 一类是表单数据
2.request.POST:获取表单数据(会把body的内容,解析一份, 解析成一个查询字典)
3.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()
1.初始化项目结构
└─shiyanlou_project 项目根路径
│ .gitignore 提交git仓库时,不提交的文件必须要在这里进行标注
│ README.en.md 英文(项目介绍) │ README.md # 中文项目简介
│ requirements.txt django项目安装文件
│
├─celery_task 用来存放celery相关文件(以便分布式部署)
│ __init__.py
│
├─db 数据库相关:1.数据库初始化sql脚本; 2.数据库维护脚本,清 理,备份脚本
├─scrips 脚本目录:1.定时任务脚本;2.页面静态化脚本;处理项目脚本
├─logs 存放日志
├─packages 外部包,原始的,未配置的:1.七牛云sdk;2.阿里云短信;
└─uwsgi_conf uwsgi配置,日志,pid
│
│└─syl 真正的django项目(代码)django-admin startproject 项目名
│ apps (python包) Django各种app模块
│ libs (python包) 七牛云sdk+配置(外部下载)
│ utils (python包) 在这里插入图片描述
小工具,常用函数(自己写的)
│ static
│ templates
│ syl(项目配置)
│ manager.py
2.创建Django项目
root@dev:shiyanlou_project workon syl (syl)
root@dev:shiyanlou_project cd /aaa/shiyanlou_project/ (syl)
root@dev:shiyanlou_project django-admin startproject syl
注:创建三个python包, apps、utils、libs
- 使用pycharm打开项目
1.右击---->编辑配置----->
- 2.文件---->设置----->
- 文件---->设置----->
3.创建user模型
- 3.1 创建用户模型user
python ../manage.py startapp user 创建user模型
- 3.2 在setting.py中注册user模型(第一步)
INSTALLED_APPS = [ 'user.apps.UserConfig', ]
注:pycharm无法联想,需要把apps文件夹设置为源根
- 3.3 syl/urls.py添加主路由(第二步)
urlpatterns = [
path('user/', include('user.urls')),
]
- 3.5 syl/settings.py中添加apps路径
把apps目录插入,到系统包搜索路径第一个位置中
sys.path.insert(0,os.path.join(BASE_DIR,'apps'))
- 3.4 创建 user/urls.py子路由文件(第三步)
from django.urls import path
urlpatterns = [
]
重写Django默认认证用户模型
- 4.1 user/models.py创建模型:从写django user表
from django.db import models
from django.contrib.auth.models import AbstractUser
# Create your models here.
class User(AbstractUser):
phone = models.CharField('手机号',max_length=20)
img = models.ImageField(upload_to='user',null=True)
nick_name = models.CharField('昵称',max_length=20)
address = models.CharField('地址',max_length=255)
class Meta:
db_table = 'tb_user
- 4.2 syl/settings.py中注册自己的用户模型类
注册自己的用户模型类: 应用名.模型名,指定我们重写的User表进行身份验证
AUTH_USER_MODEL = 'user.User'
- 4.3 配置mysql
'''1.创建mysql数据库'''
mysql> create database syldb charset utf8;
'''2.在syl/settings.py中配置mysql'''
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'syldb', 指定数据库名称:MyCRM
'USER': 'root',
'PASSWORD': '1',
'HOST': '127.0.0.1',
'PORT': '3306', } }
- 4.4生成表
python manager.py makemigrations
python manager.py migrate