视图函数
定义视图
本质就是一个函数
视图的参数
一个HttpRequest 实例
通过正则表达式组获取的位置参数
通过正则表达式组获得的关键字参数
在应用目录下默认有 views.py 文件,一般视图都定义在这个文件中
如果处理功能过多,可以将函数定义到不同的 py文件中
新建views1.py
from django.http import HttpResponse
def index(request):
return HttpResponse("你好")
在 urls.py 中修改配置
from . import views1
url(r'^$', views1.index, name='index'),
错误视图
Django 原生自带几个默认视图用于处理 HTTP 错误
404 (page not found) 视图
当抛出Http404 异常时, Django 会加载一个特殊的 view 方法
django.views.defaults.page_not_found 处理 404 错误。
它负责加载和渲染 404.html 模板文件。
这意味着我们必须在模板根目录定义 404.html 模板文件,该模板文件应用于所有的 404
异常。
defaults.page_not_found(request, template_name='404.html')
默认的404 视图将传递一个变量给模板:request_path,它是导致错误的 URL
如果Django检测URLconf中的每个正则表达式后没有找到匹配的内容将调用404视图
如果在settings 中 DEBUG 设置为True,那么将永远不会调用 404 视图,而是显示
URLconf 并带有一些调试信息
在 templates 中创建404.html
<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
找不到了
{{request_path}}
</body>
</html>
在 settings.py 中修改调试
DEBUG = False
ALLOWED_HOSTS = ['*', ]
请求一个不存在的地址
http://127.0.0.1:8000/test/
500 (server error) 视图
当 view 代码发生运行时错误时,Django 将会调用默认地 view 方法
django.views.defaults.server_error, 该方法加载渲染 500.html 模板文件。
这意味着我们必须在模板根目录定义 500.html 模板文件,该模板文件应用于所有的服务
器错误。
defaults.server_error(request, template_name='500.html')
默认的500 视图不会传递变量给 500.html 模板
如果在settings 中 DEBUG 设置为True,那么将永远不会调用 500 视图,而是显示
URLconf 并带有一些调试信息
400 (bad request) 视图
from django.views import defaults
defaults.bad_request(request, template_name='400.html')
错误来自客户端的操作
当用户进行的操作在安全方面可疑的时候,例如篡改会话 cookie
Reqeust对象
HttpReqeust对象
服务器接收到http 协议的请求后,会根据报文创建 HttpRequest 对象
视图函数的第一个参数是 HttpRequest 对象
在 django.http 模块中定义了 HttpRequest 对象的 API
属性
下面除非特别说明,属性都是只读的
path:一个字符串,表示请求的页面的完整路径,不包含域名
method:一个字符串,表示请求使用的 HTTP 方法,常用值包括:'GET'、'POST'
encoding:一个字符串,表示提交的数据的编码方式
o 如果为None 则表示使用浏览器的默认设置,一般为 utf-8
o 这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的
任何访问将使用新的 encoding 值
GET:一个类似于字典的对象,包含 get 请求方式的所有参数
POST:一个类似于字典的对象,包含 post 请求方式的所有参数
FILES:一个类似于字典的对象,包含所有的上传文件
COOKIES:一个标准的 Python 字典,包含所有的cookie,键和值都为字符串
session:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当 Django 启
用会话的支持时才可用,详细内容见“状态保持”
方法
is_ajax():如果请求是通过 XMLHttpRequest 发起的,则返回 True
QueryDict对象
定义在django.http.QueryDict
request 对象的属性 GET、POST 都是QueryDict 类型的对象
与 python 字典不同,QueryDict 类型的对象用来处理同一个键带有多个值的情况
方法get():根据键获取值
o 只能获取键的一个值
o 如果一个键同时拥有多个值,获取最后一个值
dict.get('键',default)
或简写为
dict['键']
方法getlist():根据键获取值
o 将键的值以列表返回,可以获取一个键的多个值
dict.getlist('键',default)
GET属性
QueryDict 类型的对象
包含get 请求方式的所有参数
与 url 请求地址中的参数对应,位于?后面
参数的格式是键值对,如 key1=value1
Python之:Django框架
奇酷学院高级讲师:郭建涛
多个参数之间,使用&连接,如 key1=value1&key2=value2
键是开发人员定下来的,值是可变的
示例如下
创建视图getTest1 用于定义链接,getTest2 用于接收一键一值,getTest3 用于接收一
键多值
def getTest1(request):
return render(request,'booktest/getTest1.html')
def getTest2(request):
return render(request,'booktest/getTest2.html')
def getTest3(request):
return render(request,'booktest/getTest3.html')
项目url 配置
urlpatterns = [
path('admin/', admin.site.urls),
url(r'^ booktest/', include('booktest.urls',namespace='booktest')),
]
应用url 配置
url(r'^getTest1/$', views.getTest1),
url(r'^getTest2/$', views.getTest2),
url(r'^getTest3/$', views.getTest3),
创建getTest1.html,定义链接
<html>
<head>
<title>Title</title>
</head>
<body>
链接1:一个键传递一个值
<a href=" /booktest/getTest2/?a=1&b=2">gettest2</a>
链接2:一个键传递多个值
<a href=" /booktest/getTest3/?a=1&a=2&b=3">gettest3</a>
</body>
</html>
完善视图getTest2 的代码
def getTest2(request):
a=request.GET['a']
b=request.GET['b']
context={'a':a,'b':b}
return render(request,'booktest/getTest2.html',context)
创建getTest2.html,显示接收结果
<html>
<head>
<title>Title</title>
</head>
<body>
a:{{ a }}
b:{{ b }}
</body>
</html>
完善视图getTest3 的代码
def getTest3(request):
a=request.GET.getlist('a')
b=request.GET['b']
context={'a':a,'b':b}
return render(request,'booktest/getTest3.html',context)
创建getTest3.html,显示接收结果
<html>
<head>
<title>Title</title>
</head>
<body>
a:{% for item in a %}
{{ item }}
{% endfor %}
b:{{ b }}
</body>
</html>
POST属性
QueryDict 类型的对象
包含post 请求方式的所有参数
与 form 表单中的控件对应
问:表单中哪些控件会被提交?
答:控件要有name 属性,则 name 属性的值为键,value 属性的值为键,构成键值对
提交
o 对于checkbox 控件,name 属性一样为一组,当控件被选中后会被提交,存在一键多值
的情况
键是开发人员定下来的,值是可变的
示例如下
定义视图postTest1
def postTest1(request):
Python之:Django框架
奇酷学院高级讲师:郭建涛
return render(request,'booktest/postTest1.html')
配置url
url(r'^postTest1$',views.postTest1)
创建模板postTest1.html
<html>
<head>
<title>Title</title>
</head>
<body>
<form method="post" action="/booktest/postTest2/">
<br />{% csrf_token %}<br />
姓名:<input type="text" name="uname"/>
密码:<input type="password" name="upwd"/>
性别:<input type="radio" name="ugender" value="1"/>男
<input type="radio" name="ugender" value="0"/>女
爱好:<input type="checkbox" name="uhobby" value="胸口碎大石"/>胸口碎大石
<input type="checkbox" name="uhobby" value="跳楼"/>跳楼
<input type="checkbox" name="uhobby" value="喝酒"/>喝酒
<input type="checkbox" name="uhobby" value="爬山"/>爬山
<input type="submit" value="提交"/>
Python之:Django框架
奇酷学院高级讲师:郭建涛
</form>
</body>
</html>
创建视图postTest2 接收请求的数据
def postTest2(request):
uname=request.POST['uname']
upwd=request.POST['upwd']
ugender=request.POST['ugender']
uhobby=request.POST.getlist('uhobby')
context={'uname':uname,'upwd':upwd,'ugender':ugender,'uhobby':uhobby}
return render(request,'booktest/postTest2.html',context)
配置url
url(r'^postTest2$',views.postTest2)
创建模板postTest2.html
<html>
<head>
<title>Title</title>
</head>
<body>
Python之:Django框架
奇酷学院高级讲师:郭建涛
{{ uname }}
{{ upwd }}
{{ ugender }}
{{ uhobby }}
</body>
</html>
注意:表单页面添加<br />{% csrf_token %}<br />
或者给postTest2 方法添加修饰器@csrf_exempt
# 网页
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<a href="/books/test2/?a=1&b=2">test2</a>
<a href="/books/test3/?a=1&b=2&b=3&b=4">test3</a>
</body>
</html>
# urls.py
from django.conf.urls import url
from . import views
urlpatterns = [
url(r"^$", views.index),
url(r"^detail/(\d+)/$", views.detail),
url(r"^test1/$", views.test1),
url(r"^test2/$", views.test2),
url(r"^test3/$", views.test3),
]
# view.py
def test1(request):
return render(request, "books/test1.html")
def test2(request):
a = request.GET['a']
b = request.GET['b']
context = {"a": a, "b": b}
return render(request, "books/test2.html", context)
def test3(request):
a = request.GET["a"]
b = request.GET.getlist("b")
context = {"a": a, "b": b}
return render(request, "books/test3.html", context)