今日的内容:

a. 路由系统
1. 创建app
2. 路由的分组
3. 路由的分发
- 正则表达式匹配 b. django的orm(模型model)
1. 创建模型的步骤
2. orm基本的增删改查
3. 正向查询和反向查询

注意事项:

1. 前台传给后台一个列表时,后端如何接受:
request.POST.getlist(字段名) 2. 前台传给后台一个列表时,需要在ajax请求中增加一个参数:
traditional: true 3. 多选框设置选中状态时,可以使用
$("select的选择器").val(列表) 4. cookie的参数设置 obj = render(request,'a.html')
obj.set_cookie(key,values,max_age,expires,path,
domain,secure,httponly)
参数详解
"""
key, 键
value=, 值
max_age=None, 超时时间
expires=None, 指定过期时间IE 专用 date = datetime.datetime() expires=date
path='/', cookie有效路径
domain=None, Cookie生效的域名
secure=False, https传输
httponly=False 只能http协议传输,无法被JavaScript获取(不是绝对,底层抓包可以获取到也可以被覆盖)
"""
5. 删除Cookie
def logout(request):
rep = redirect("/login/")
rep.delete_cookie("user") # 删除用户浏览器上之前设置的usercookie值
return rep 6. 获取Cookie
username = request.COOKIES.get('username') # 取出登录用户名 7. cookie的加盐
#通过加盐的方式为cookie签名。
obj.set_signed_cookie('kkk','vvv', salt='123456')
#获取经过签名后的cookie值。
request.get_signed_cookie('kkk', salt='123456')
# 目录结构
migrations # 模型操作的迁移文件
init
admin # 管理文件,django admin的时候会用到
apps # 应用信息定义文件,在其中生成了类AppCongfig,该类用于定义应用名等Meta数据
models # 添加模块层数据类的文件,orm框架时使用
tests # 测试代码文件
views # 视图文件

路由分组

对多个视图进行一个分组,比如class为一个组,所有跟class相关的增,删,改,查视图都放在这个app中。各司其职,互不干扰。相比之前把所有的代码写到urls中,功能分划更清晰。

创建app的两种方式:

1. 使用pycharm创建django项目时,可以创建。缺点:只能创建一个
2. 命令行创建python3 manage.py startapp app名称(可创建多个),
  • django使用的什么版本的解释器,就需要用对应的解释器创建app
  • 需要在对应的目录下创建

分组:

第一种方式

a. 项目下的urls.py中

from *** import views
urlpatterns = [
url(r'^test/', views.test),
] # 缺点,只能导入一个app,多个app会导致名称空间被污染
第二种方式
  1. django项目下的urls.py文件,注意:需要导入include模块
from django.conf.urls import url,include

urlpatterns = [
url(r'^classes/',inclued("classes.urls")),
url(r'^student/',inclued("student.urls")),
url(r'^teacher/',inclued("teacher.urls"))
]
  1. 在对应的app下,创建一个urls.py文件

  2. 对应app的urls.py

form django.conf.urls import url

from classes import views

urlpatterns = [
url(r'^get_classes/',views.get_classes),
]
  1. 对应app下的views.py文件内容为:
from django.shortcuts import render,HttpResponse

# Create your views here.

def get_classes(request):

   return HttpResponse("get_classes")

第二种方式的总结:

  • 客户端访问127.0.0.1:8000/classes/get_classes时,先进入到项目下的urls.py文件进行匹配
  • 根据项目下urls.py中的对应关系,进入到各个app项目下的urls.py文件中进行匹配
  • 根据各个app下的urls.py中的对应关系,匹配成功请求路径后,执行对应app项目下views.py文件下的函数。

路由分发

from app01 import views
urlpatterns = [
url(r'^test/(?P<id>\w+)/(?P<name>\w+)', views.test),
] # app01项目下views.py文件:
def test(request,name,id):
print(name)
print(id)
return HttpResponse("test") # 浏览器访问
http://127.0.0.1:8000/test/0123/plf # -------------------------views.py中打印结果---------------------
plf
0123

当浏览器中输入一个不存在的地址时,我们可以在浏览器中匹配对应的路径,然后为不存在的url,专门设置一个页面

from app01 import views
urlpatterns = [
url(r'^', views.notfound),
]
反向路由

当一个路径很长的时候,我们可以在路由系统中,设置一个变量a,用来代替这个路径,之后我们在form表单中action中写入{% url "a" %}即可.

# 路由系统中的写法
urlpatterns = [
url(r'^logindbsjhalbdhaskbhdkjsabhdkbashkdbhsabdhsja/$', views.login, name='test'),
] # 对应的html的页面中写法:
<form action="/test/" method="post">
<input type="text">
</form>

django中请求处理方式有2种:FBV 和 CBV

第一种:FBV(function base views)

就是在视图里使用函数处理请求

urls.py
from django.conf.urls import url, include
# from django.contrib import admin
from mytest import views urlpatterns = [
# url(r'^admin/', admin.site.urls),
url(r'^index/', views.index),
views.py
from django.shortcuts import render

def index(req):
if req.method == 'POST':
print('method is :' + req.method)
elif req.method == 'GET':
print('method is :' + req.method)
return render(req, 'index.html')

第二种:CBV(class base views)

就是在视图里使用类处理请求。

urls.py
from mytest import views

urlpatterns = [
# url(r‘^index/‘, views.index),
url(r‘^index/‘, views.Index.as_view()),
] # 注:url(r‘^index/‘, views.Index.as_view()), 是固定用法。
views.py
from django.views import View

class Index(View):
def get(self, req):
print('method is :' + req.method)
return render(req, 'index.html') def post(self, req):
print('method is :' + req.method)
return render(req, 'index.html') # 注:类要继承 View ,类中函数名必须小写。
'''
'get', 'post', 'put', 'patch', 'delete', 'head', 'options', 'trace'
form 只支持 post和 get
ajax 支持 所有的方法
'''

ORM框架

1. 先配置mysql的连接地址

# 在settings.py文件中,写入自己需要连接的数据库
DATABASES = {
# 'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
# }
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME':'orm',
'USER': 'root',
'PASSWORD': '123456',
'HOST': '192.168.81.161',
'PORT': '3306',
}
}

2. 在app中的__init__.py文件中导入pymysql模块

import pymysql
pymysql.install_as_MySQLdb()

3. 在app项目下models.py文件中创建表.一个类一个表

# 类需要继承models.Model

from django.db import models
# Create your models here.
class UserInfo(models.Model):
id = models.AutoField(primary_key=True)
name = models.CharField(max_length=32)
age = models.CharField(max_length=32)
ut = models.ForeignKey("UserType",null=True)

4. 修改配置文件

​ 把我们的应用添加到对应的settings.py的INSTALLED_APPS 中:

INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'****', #我们创建的应用
]

4. 创建表

python manage.py makemigrations  ## 生成迁移文件
python manage.py migrate ## 生成实际的表 ps: 如果修改了models.py中的代码,需要重新执行上面的两行代码

5. 基本操作

第一种方式
models.users.objects.create(username='xsmile',password=12345) 第二种方式
a = {'username':"plf",'passsword':'123456'}
models.users.objects.create(**a) 第三种方式:插入多条数据
info = [
models.UserInfo(name="root1",age=34,ut_id=1),
models.UserInfo(name="root2",age=34,ut_id=2),
models.UserInfo(name="root3",age=34,ut_id=3),
models.UserInfo(name="root4",age=34,ut_id=4),
models.UserInfo(name="root5",age=34,ut_id=5),
models.UserInfo(name="root6",age=34,ut_id=6),
models.UserInfo(name="root7",age=34,ut_id=7),
]
models.UserInfo.objects.bulk_create(info)
删除
Test.objects.filter(name__contains='jack').delete()

Test.objects.filter(name__contains='apollo1').update(name='Jack')

单表查询


models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值
models.Tb1.objects.filter(id__in=[11, 22, 33]) # 获取id等于11、22、33的数据
models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in
models.Tb1.objects.filter(name__contains="ven") # 获取name字段包含"ven"的
models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
models.Tb1.objects.filter(id__range=[1, 3]) # id范围是1到3的,等价于SQL的bettwen and
类似的还有:startswith,istartswith, endswith, iendswith 
date字段还可以:
models.Class.objects.filter(first_day__year=2017)

多表查询(外键查询)

1. 正向查询(通过关联的字段ut,直接使用点语法获取另外一张表的字段数据)
objs = models.UserInfo.objects.filter(ut_id__gt=2,ut__title="正常员工")
print(objs)
for i in objs:
print(f"id:{i.id} {i.name} {i.age} {i.ut.title}")

正向查询

第一种:按对象查找

语法

对象.关联字段.字段

book_obj = models.Book.objects.first()  # 第一本书对象
print(book_obj.publisher) # 得到这本书关联的出版社对象
print(book_obj.publisher.name) # 得到出版社对象的名称

第二种:按照字段查找

语法

关联字段__字段

print(models.Book.objects.values_list("publisher__name"))

反向查询

第一种:按照对象查找

语法

对象.表名_set

publisher_obj = models.Publisher.objects.first()  # 找到第一个出版社对象
books = publisher_obj.book_set.all() # 找到第一个出版社出版的所有书
titles = books.values_list("title") # 找到第一个出版社出版的所有书的书名

第二种:按照字段查找

语法

表名__字段

titles = models.Publisher.objects.values_list("book__title")

django之路由分组,路由分发,FBV,CBV,ORM框架的更多相关文章

  1. 【Gin-API系列】实现路由分组(七)

    在之前的文章介绍中我们已经完成了一个API服务的全链路请求设计.调用方式可以看Test目录的代码 // src/test/request_test.go func TestAPI_Request(t ...

  2. Django 路由视图FBV/CBV

    路由层  url路由层结构 from django.conf.urls import url from django.contrib import admin from app01 import vi ...

  3. Python菜鸟之路:Django 路由补充1:FBV和CBV - 补充2:url默认参数

    一.FBV和CBV 在Python菜鸟之路:Django 路由.模板.Model(ORM)一节中,已经介绍了几种路由的写法及对应关系,那种写法可以称之为FBV: function base view ...

  4. django之路由分组,反向解析,有名,无名分组

    路由层 无名分组 有名分组 反向解析 路由分发 名称空间 伪静态的概念 urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'test',vi ...

  5. Django路由系统---django重点之url映射分发

    django重点之url映射分发 在全局项目的urls.py中进行子项目的映射,然后在子项目中创建一个urls.py去处理自己项目中的请求,同时也实现了代码的解耦 添加路由分发的原则[全局urls.p ...

  6. Django路由配置之子路由include(URL分发)

    子路由include(URL分发) 在一个项目中可能存在多个应用,为了方便区分和管理,在项目的总路由urls.py中会进行路由分发: (1)项目总路由导入from  django.conf.urls  ...

  7. Django基础三之路由、视图、模板

    Django基础三之路由.视图.模板 目录 Django基础三之路由.视图.模板 1. Django 请求和返回周期 1.1 路由层之路由匹配 1.2 有名分组 1.3 无名分组 2. 反射解析 3. ...

  8. Django学习---路由url,视图,模板,orm操作

    Django请求周期 url ->  路由系统  ->函数或者类 -> 返回字符串 或者 模板语言 Form表单提交: 点击提交 -> 进入url系统  ->  执行函数 ...

  9. Django FBV/CBV、中间件、GIT使用

    s5day82 内容回顾: 1. Http请求本质 Django程序:socket服务端 a. 服务端监听IP和端口 c. 接受请求 \r\n\r\n:请求头和请求体 \r\n & reque ...

随机推荐

  1. 使用VS2015调试Qt5.9.5源码

    调试的前提 1.Qt5.9.5源码. 2.Qt5.9.5对应VS2015版本的pdb文件. 前提1在安装Qt时勾选源代码选项即可,这样安装后的Qt目录会多出一个“Src”的目录,里面就是Qt的源码. ...

  2. Android Studio 初级控件笔记

    Android支持的像素单位 Android支持的像素单位有:px(像素).in(英寸).mm(毫米).pt(磅,1/72英寸).dp(与设备无关的显示单位).dip(就是dp).sp(用于设置字体大 ...

  3. 条件锁condition与Queue()

    在学习之前你应该先了解锁和队列基础 import queue import time import random import threading import asyncio import logg ...

  4. 程序员必需知道的Chrome使用技巧(入门篇)

    浏览器版本 Chrome Canary 新增一些没有经过Google工程师的测试或使用的浏览器功能版本.Chrome Dev让大多数开发人员主要使用此版本来测试对浏览器的重大版本功能版本.Chrome ...

  5. Redis01——Redis介绍

    1.NoSQL数据库概述 NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库. NoSQL 不依赖业务逻辑方式存储,而以简单的key-value模式 ...

  6. C++之Boost准标准库配置

    下载安装 进入官网下载地址:https://www.boost.org/users/download/ 本教程直接下载官方已编译库,不涉及源代码手动编译 点击官方编号好的链接,然后进入一个下载地址:h ...

  7. JSON--WEB SERVICE

    Query ajax webservice:get 和 post 一.GET 方式 客户端 复制代码代码如下: var data = { classCode: "0001"}; / ...

  8. JVM的方法区和永久带是什么关系?

    什么是方法区? 方法区(Method Area)是jvm规范里面的运行时数据区的一个组成部分,jvm规范中的运行时数据区还包含了:pc寄存器.虚拟机栈.堆.方法区.运行时常量池.本地方法栈. 方法区存 ...

  9. 深度学习之tensorflow框架(上)

    import tensorflow as tf import os os.environ[' def tensorflow_demo(): #原生python加法运算 a = 2; b=3; c=a+ ...

  10. 09day 命令提示符优化及yum优化

    export PS1='\[\e[32;1m\][\u@\h \W]\$ \[\e[0m\]' 设置颜色 内容 结束 export PS1='\[\e[30;1m\][\u@\h \W]\$ \[\e ...