管理器Manage
管理器是Django的模型进行数据库操作的接口,Django应用的每个模型类都拥有至少一个管理器
管理器对象objects,(默认)
作用:
- 修改原始查询集
- 向管理器类中添加额外的方法,
定义管理器对象类
booktest/models.py下
class BookInfoManager(models.Manager):
# 重写all()方法
def all(self):
# 筛选出 isDelete = 0 的全部返回
return super().all().filter(isDelete=False)
def create_book(self, title, pub_date):
# 调用此方法直接将对象保存到数据库
book = self.model()
book.btitle =title
book.bpub_date=pub_date
book.bread = 0
book.bcomment = 0
book.isDelete = False
book.save()
return book
为模型类BookInfo定义管理器books
class BookInfo(models.Model):
books = BookInfoManager()
调用
from datetime import date
book=BookInfo.books.create_book("射雕英雄传",date(1980,1,1))
元选项
数据表名称
<app_name>_<model_name>
例:
booktest_bookinfo
例:指定BookInfo模型类生成的数据表名为bookinfo。
#定义图书模型类BookInfo
class BookInfo(models.Model):
#定义元选项
class Meta:
db_table = 'bookinfo' # 指定模型类对应表名
URL
用户通过在浏览器的地址栏中输入网址请求网站,对于Django开发的网站,由哪一个视图进行处理请求,是由url匹配找到的。
配置
settings.py中通过ROOT_URLCONF指定url配置,默认已经有此配置。
urls.py可以看到默认配置。
- urls.py中进行包含配置,在各自应用中创建具体配置。
- 定义urlpatterns列表,存储url()对象,这个名称是固定的。
- urlpatterns中的每个正则表达式在第一次访问它们时被编译,这使得运行很快。
语法
url()对象,被定义在django.conf.urls包中,有两种语法结构
语法一
一般在自定义应用中创建一个urls.py来定义url。
url(正则,include('应用.urls'))
语法二
指定URL和视图函数的对应关系。
在应用内部创建urls.py文件,指定请求地址与视图的对应关系
url(正则,'视图函数名称')
- view视图的处理必须返回HttpResponse对象或者子类对象
from django.shortcuts import render
from booktest.models import *
def index(request):
books=BookInfo.objects.all()
return render(request,'booktest/index.html',{'books':books})
- 正则部分推荐使用r,表示字符串不转义,这样在正则表达式中使用\只写一个就可以。
- 不能在开始加反斜杠,推荐在结束加反斜杠。
在视图中添加位置参数
booktest/urls.py文件,定义与这个地址匹配的url
url(r'^delete\d+/$',views.show_arg),
booktest/views.py中创建视图show_arg。
def show_arg(request):
return HttpResponse('show_arg')
启动服务端
- 位置参数
直接使用小括号,通过位置参数传递给视图。
url(r'^delete(\d+)/$',views.show_arg),
视图show_arg
def show_arg(request,id):
return HttpResponse('show arg {}'.format(id))
- 关键字参数
在正则表达式部分为组命名
?P部分表示为这个参数定义的名称为id
url(r'^delete(?P<id1>\d+)/$',views.show_arg),
视图show_arg此时必须要有一个参数名为id1
def show_arg(request,id1):
return HttpResponse('show{}'.format(id1))
调试信息
当DEBUG=False,
ALLOWED_HOSTS = ['*']时
关闭
404错误页面
在templates新建立404.html
500错误页面
500错误,调用内置错误视图,使用templates/500.html模板渲染。
如果在settings中DEBUG设置为True,那么将永远不会调用505视图,而是显示URLconf 并带有一些调试信息
HttpReqeust对象
属性
path:一个字符串,表示请求的页面的完整路径,不包含域名和参数部分。
-
method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET'、'POST'。
- 在浏览器中给出地址发出请求采用get方式,如超链接。
- 在浏览器中点击表单的提交按钮发起请求,如果表单的method设置为post则为post请求。
-
encoding:一个字符串,表示提交的数据的编码方式。
- 如果为None则表示使用浏览器的默认设置,一般为utf-8。
- 这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问将使用新的encoding值。
GET:QueryDict类型对象,类似于字典,包含get请求方式的所有参数。
POST:QueryDict类型对象,类似于字典,包含post请求方式的所有参数。
FILES:一个类似于字典的对象,包含所有的上传文件。
COOKIES:一个标准的Python字典,包含所有的cookie,键和值都为字符串。
session:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当Django 启用会话的支持时才可用,详细内容见"状态保持"。
GET属性
- 分析请求参数,键为'a'、'b'、'c',值为'10'、'20'、'python'。
- 在Django中可以使用HttpRequest对象的GET属性获得get方方式请求的参数。
- GET属性是一个QueryDict类型的对象,键和值都是字符串类型。
- 键是开发人员在编写代码时确定下来的。
- 值是根据数据生成的。
POST属性
使用form表单请求时,method方式为post则会发起post方式的请求,需要使用HttpRequest对象的POST属性接收参数,POST属性是一个QueryDict类型的对象。
问:表单form如何提交参数呢?
答:表单控件name属性的值作为键,value属性的值为值,构成键值对提交。
- 如果表单控件没有name属性则不提交。
- 对于checkbox控件,name属性的值相同为一组,被选中的项会被提交,出现一键多值的情况。
- 键是表单控件name属性的值,是由开发人员编写的。
- 值是用户填写或选择的。
模拟
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<ul>
<a href="/method_show_get/">点击get提交</a>
<form method="post" action="/method_show/">
<input type="submit" value="post方式提交">
</form>
<h1>提交数据的两种方式</h1>
<p>get方式</p>
<a href="/get_submit/?a=10&b=20&c=python">点击get提交</a>
<p>post方式</p>
<form method="post" action="/post_submit/">
姓名: <input type="text" name="uname"><br>
性别: 男 <input type="radio" name="gender" value="男">
女 <input type="radio" name="gender" value="女"><br>
爱好:
吃饭 <input type="checkbox" name="hobby" value="吃饭">
睡觉 <input type="checkbox" name="hobby" value="睡觉">
打豆豆<input type="checkbox" name="hobby" value="打豆豆">
<br>
<input type="submit" value="注册">
</form>
</ul>
</body>
</html>