08.视图详解 -- 状态保持

2019-03-14  本文已影响0人  __深蓝__

Cookie

  • Cookie,有时也用其复数形式Cookies,指某些网站为了辨别用户身份、进行session跟踪而储存在用户本地终端上的数据(通常经过加密)
  • Cookie是由服务器端生成,发送给User-Agent(一般是浏览器),浏览器会将Cookie的key/value保存到某个目录下的文本文件内,下次请求同一网站时就发送该Cookie给服务器(前提是浏览器设置为启用cookie)
  • Cookie名称和值可以由服务器端开发自己定义,这样服务器可以知道该用户是否是合法用户以及是否需要重新登录等。服务器可以利用Cookies包含信息的任意性来筛选并经常性维护这些信息,以判断在HTTP传输中的状态。
  • Cookie是存储在浏览器中的一段纯文本信息,建议不要存储敏感信息如密码,因为电脑上的浏览器可能被其它人使用

Cookie的特点

设置Cookie

def cookie_set(request):
    response = HttpResponse("<h1>设置Cookie,请查看响应报文头</h1>")
    response.set_cookie('ck1', 'hello')
    return response

读取Cookie
Cookie信息被包含在请求头中,使用request对象的COOKIES属性访问。

def cookie_set(request):
    response = HttpResponse("读取Cookie,数据如下:<br>")

    if 'ck1' in request.COOKIES:
        response.write('<h1>' + request.COOKIES['ck1'] + '</h1>')
    return response

Session

  • Session以键值对的形式存储在服务端,键与Cookie中的sessionid相同,值是开发人员设置的键值对信息,进行了base64编码,过期时间由开发人员设置
  • 服务器会在Cookie中存储一个sessionid,浏览器每次请求时会将这个数据发给服务器,服务器根据收到sessionid找出对应的Session数据
  • Session用于存储敏感的、重要的信息,如真实姓名、余额、等级、验证码等

对象及方法
通过HttpRequest对象的session属性进行会话的读写操作

实例演练: 写入Session

def session_write(request):
    request.session['s1'] = 'hello'
    return HttpResponse('写session')

实例演练: 读取Session

def session_read(request):
    s1 = request.session.get('s1')
    return HttpResponse(s1)

实例演练: 删除Session

def session_test(request):
    del request.session['s1']
    return HttpResponse('ok')




- end -

上一篇 下一篇

猜你喜欢

热点阅读