django视图的定义
url的配置
-
工程下url配置
1.制定根级url配置文件,在seetings.py文件中配置ROOT_URLCONF = 'project.urls',django默认已配置。
2.在urls.py配置urlpatterns
-
应用url配置
1.创建应用,python manage.py startapp app
2.在工程目录下的urls.py中导入模块from django.conf.urls import url, include
,在urlpatterns中添加url(r'^app/', include('app.urls', namespace="myApp")
。
3.在应用中创建urls.py文件,导入模块from django.conf.urls import url
,添加urlpatterns
列表,在列表中配置自定义url。
url的配置注意事项
1.如果想要从url中获取一个值,需要对正则加小括号,如url(r'^test/(\d+)/',views.test,name='test')
。
2.匹配正则前方不需要加反斜杠,因为在工程目录下urls.py文件中进行如下配置url(r'^app/', include('app.urls', namespace="myApp")
。
3.正则前需要加r表示字符串不转义。
url的反向解析
在定义url的时候使用namespace与name对url进行命名。
urls.py中:
urlpatterns = [
url(r'^app/',include('app.urls',namespace='app'))
]
app中urls.py中:
urlpatterns = [
url(r'^index/',views.index,name='index')
]
在视图中反向解析:
from django.http import HttpResponseRedirect
from django.urls import reverse
def index(request):
return HttpResponseRedirect(reverse('app:index'))
视图函数
视图本质是一个函数,函数的参数是一个HttpRequest实例。
错误视图的定义:
404视图:找不到网页时返回,500视图:视图代码出现错误(服务器错误),400视图:错误出现在客户的操作
配置:在settings.py文件中设置DEBUG的值为
True
,为Fasle永远不会调用错误视图,ALLOWED_HOSTS = ['*']。然后再定义相对应的网页,404.html等。HttpRequest对象
概述
服务器接收http请求后,会根据报文创建HttpRequest对象,视图函数的第一个参数就是HttpRequest对象。
属性
request.path:请求的完整路径(不包括域名和端口)
request.method:表示请求的方式,常用的有GET、POST
request.encoding:表示浏览器提交的数据的编码方式,一般为utf-8
request.GET:类似字典的对象,包含了get请求的所有参数
request.POST:类似字典的对象,包含了post请求的所有参数
request.FILES:类似字典的对象,包含了所有上传的文件
request.COOKIES字典,包含所有的cookie
request.session:类似字典的对象,表示当前会话
方法
is_ajax():如果是通过XMLHttpRequest发起的,返回True
QueryDict对象
request对象中的GET、POST都属于QueryDict对象,GET对象用来获取浏览器传递过来给服务器的数据,POST用来使用表单提交实现post请求。
request.GET.get(key):作用:根据键获取值,只能获取一个值
request.POST.get(key):作用:根据键获取值,只能获取一个值
request.GET.getlist(key):将键的值以列表的形式返回,可以获取多个值
request.POST.getlist(key):将键的值以列表的形式返回,可以获取多个值
HttpResponse对象
概述
作用:给浏览器返回数据,HttpRequest对象是由django创建的,HttpResponse对象由用户创建。
from django.http import HttpResponse
# 不调用模板,直接返回数据
def index(request):
if request.method == 'GET':
return HttpResponse('欢迎访问')
# 调用模板,render方法
def index(request):
if request.method == 'GET':
data = '欢迎访问'
return render(request,'index.html',{'data':data})
属性
response.content:表示返回的内容
response.charset:编码格式
response.status_code:响应状态码
response.content-type:指定输出的MIME类型
方法
response.init():使用页面内容实例化HttpResponse对象
response.write(content):以文件的形式写入
response.flush():以文件的形式输出缓冲区
response.set_cookie(key, value='', max_age=None,exprise=None):设置cookie
response.delete_cookie(key):删除cookie,如果删除一个不存在的key,就当什么都没发生
子类HttpResponseRedirect
功能:重定向,服务器端跳转,简写:redirect(to)
from django.http import HttpResponseRedirect
from django.shortcuts import redirect
def redirects(request):
return redirect('/app/index')
状态保持
概述
http协议时无状态的,每次请求都是一次新的请求,不记得以前的请求,客户端与服务器端的一次通信就是一次会话,实现状态保持,在客户端或者服务端存储有关会话的数据。
存储方式:cookie,所有的数据存储在客户端,不要存敏感的数据,session,所有的数存储在服务端,在客户端用cookie存储session_id。
状态保持的目的:在一段时间内跟踪请求者的状态,可以实现跨页面访问当前的请求者的数据。
不同的请求者之间不会共享这个数据,与请求者一一对应的
启用session
在seetings.py
文件django已默认启用。
INSTALLED_APPS = [
'django.contrib.sessions',
]
MIDDLEWARE = [
'django.contrib.sessions.middleware.SessionMiddleware',
]
使用session
启用session后,每个HttpRequest对象都有一个session属性,就是一个类似字典的对象
取session值
session = request.session.get(key) # 根据键获取session值
设置session值
request.session[key] = value # 设置session值
清除session值
from django.contrib.auth import logout
request.session.clear() # 清空所有的会话
request.session.flush() # 删除当前的会话并删除会话的cookie
logout(request) # django自带的清除cookie的方法
设置过期时间
如果不设置,两个星期后过期
request.session.set_expiry(10) # 10秒后过期
request.session.set_expiry(0) # 关闭浏览器失效
request.session.set_expiry(None) # 永不过期