django之view

一、URL

  • 视图接受web请求返回web响应
  • 视图就是一个python函数,被定义在views.py中
  • 响应可以是一个网页的html内容,一个重定向,或者一个404错误
  • 响应处理过程如下:
    用户在浏览器输入网址——django获取信息后,去除域名和端口部分,解析剩下的url——拿到url后,浏览器会去自动匹配所有的url(正则部分),直到匹配成功——找到对应的视图函数,接受request请求,通过模型获取数据库数据,并调用模板,最后返回response对象

关于正则匹配问题:

正则当中加上括号表示获取该值,此时对应的视图函数中必须接受一个参数接收这个值

urlpatterns=[
    url(r'^$',views.index),
    url(r'^(\d+)$',views.detail)
]
def detail(request,p1):
    return HttpResponse(p1)

正则表达式通过位置或关键词参数传递给视图,需要指定参数

urlpatterns=[
    url(r'^$',views.index),
    url(r'^(?P<p2>\d+)/(?P<p3>\d+)/(?P<p1>\d+)/$',views.detail)
]

二、视图
视图本身是一个函数,视图的参数有:

  • 一个HttpRequest实例
  • 通过正则表达式组获取的位置参数
  • 通过正则表达式组获得的关键字参数

404视图
与url请求地址中的参数对应,位于?后面的是参数
如果在settings中DEBUG设置为True,那么将永远不会调用404视图,而是显示URLconf 并带有一些调试信息
在这里插入图片描述
如果设置DEBUG为False(ALLOWED_HOSTS = [’*’]),则会访问404.HTML模板在这里插入图片描述
500视图(server error),错误来自服务器端

400视图(bad request),错误来自客户端操作

三、HttpRequest对象
在django.http模块中定义了HttpRequest对象的API
属性
下面除非特别说明,属性都是只读的
path:一个字符串,表示请求的页面的完整路径,不包含域名
method:一个字符串,表示请求使用的HTTP方法,常用值包括:‘GET’、‘POST’
encoding:一个字符串,表示提交的数据的编码方式
如果为None则表示使用浏览器的默认设置,一般为utf-8
这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问将使用新的encoding值
GET:一个类似于字典的对象,包含get请求方式的所有参数
POST:一个类似于字典的对象,包含post请求方式的所有参数
FILES:一个类似于字典的对象,包含所有的上传文件
COOKIES:一个标准的Python字典,包含所有的cookie,键和值都为字符串
session:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当Django 启用会话的支持时才可用,详细内容见“状态保持”

QueryDict对象
定义在django.http.QueryDict
request对象的属性GET、POST都是QueryDict类型的对象
方法get():根据键获取值,一键一值
在这里插入图片描述
方法getlist():一键多值
在这里插入图片描述
POST属性
post与form表单中的控件对应,form表单中,method设置为post,action设置为提交的地址,控件要有name属性,则name属性的值为键,value属性的值为键,构成键值对提交

post请求的时候要在setting中注释掉csrf设置,否则出错
在这里插入图片描述

四、HttpResponse对象
在django.http模块中定义了HttpResponse对象的API
HttpRequest对象由Django自动创建,HttpResponse对象由程序员创建

调用模板

from django.http import HttpResponse
from django.template import RequestContext, loader

def index(request):
    t1 = loader.get_template('polls/index.html')
    context = RequestContext(request, {'h1': 'hello'})
    return HttpResponse(t1.render(context))

属性
content:表示返回的内容,字符串类型,body部分
charset:表示response采用的编码字符集,字符串类型
status_code:响应的HTTP响应状态码
content-type:指定输出的MIME类型,html、xml、jpg、png

方法
init :使用页内容实例化HttpResponse对象
write(content):以文件的方式写
flush():以文件的方式输出缓存区
cookie设置
数据缓存设置,浏览器向服务器请求数据,服务器返回给浏览器后会缓存,下次请求时不需要再次向服务器请求数据,而是直接从缓存中请求。
set_cookie(key, value=’’, max_age=None, expires=None):设置Cookie
key、value都是字符串类型
max_age是一个整数,表示在指定秒数后过期
expires是一个datetime或timedelta对象,会话将在这个指定的日期/时间过期,注意datetime和timedelta值只有在使用PickleSerializer时才可序列化
max_age与expires二选一
如果不指定过期时间,则两个星期后过期

def cookieTest(request):
    response=HttpResponse()
    cookie=request.COOKIES
    if cookie.has_key('t1'):
        response.write(cookie['t1'])
    # response.set_cookie('t1','abc')
    return response

子类HttpResponseRedirect
重定向,服务器端跳转

from django.http import HttpResponse,HttpResponseRedirect
def redTest1(request):
    #return HttpResponseRedirect('/booktest/redTest2/')
    return redirect('/booktest/redTest2/')

def redTest2(request):
    return HttpResponse('这是转向来的页面')

五、状态保持session
http协议是无状态的:每次请求都是一次新的请求,不会记得之前通信的状态
客户端与服务器端的一次通信,就是一次会话
实现状态保持的方式:在客户端或服务器端存储与会话有关的数据
存储方式包括cookie、session,会话一般指session对象
使用cookie,所有数据存储在客户端,注意不要存储敏感信息
推荐使用sesison方式,所有数据存储在服务器端,在客户端cookie中存储session_id
状态保持的目的是在一段时间内跟踪请求者的状态,可以实现跨页面访问当前请求者的数据
注意:不同的请求者之间不会共享这个数据,与请求者一一对应

启用session
在setting.py文件中,以下默认都是存在的,
向INSTALLED_APPS列表中添加:
‘django.contrib.sessions’,

向MIDDLEWARE_CLASSES列表中添加:
‘django.contrib.sessions.middleware.SessionMiddleware’,

使用session
启用会话后,每个HttpRequest对象将具有一个session属性,它是一个类字典对象
get(key, default=None):根据键获取会话的值
clear():清除所有会话
flush():删除当前的会话数据并删除会话的Cookie
del request.session[‘member_id’]:删除会话

会话过期时间
set_expiry(value):设置会话的超时时间
如果没有指定,则两个星期后过期
如果value是一个整数,会话将在values秒没有活动后过期
若果value是一个imedelta对象,会话将在当前时间加上这个指定的日期/时间过期
如果value为0,那么用户会话的Cookie将在用户的浏览器关闭时过期
如果value为None,那么会话永不过期
修改视图中login_handle函数,查看效果

def login_handle(request):
    request.session['uname'] = request.POST['uname']
    # request.session.set_expiry(10)
    # request.session.set_expiry(timedelta(days=5))
    # request.session.set_expiry(0)
    # request.session.set_expiry(None)
    return redirect(reverse('main:index'))

存储session

  • 基于数据库的会话:这是django默认的会话存储方式,需要添加django.contrib.sessions到的INSTALLED_APPS设置中,运行manage.py migrate在数据库中安装会话表,可显示指定为
  • SESSION_ENGINE=‘django.contrib.sessions.backends.db’
  • 基于缓存的会话:只存在本地内在中,如果丢失则不能找回,比数据库的方式读写更快
  • SESSION_ENGINE=‘django.contrib.sessions.backends.cache’
  • 可以将缓存和数据库同时使用:优先从本地缓存中获取,如果没有则从数据库中获取
  • SESSION_ENGINE=‘django.contrib.sessions.backends.cached_db’

使用Redis缓存session
会话还支持文件、纯cookie、Memcached、Redis等方式存储,下面演示使用redis存储

安装包
pip install django-redis-sessions

修改settings中的配置,增加如下项
SESSION_ENGINE = ‘redis_sessions.session’
SESSION_REDIS_HOST = ‘localhost’
SESSION_REDIS_PORT = 6379
SESSION_REDIS_DB = 0
SESSION_REDIS_PASSWORD = ‘’
SESSION_REDIS_PREFIX = ‘session’

管理redis的命令
启动:sudo redis-server /etc/redis/redis.conf
停止:sudo redis-server stop
重启:sudo redis-server restart
redis-cli:使用客户端连接服务器
keys *:查看所有的键
get name:获取指定键的值
del name:删除指定名称的键

猜你喜欢

转载自blog.csdn.net/Albert_Ejiestein/article/details/88957001