day13 cookie与session和中间件

cookie与session简介
http协议
四大特性
1.基于请求响应
2.基于TCP\IP作用于应用层之上
3.无状态
基于http协议通信的服务端无法保存客户端状态
纵使见她千百遍 我都当她如初见
4.无(短)连接

随着互联网的发展 很多网站都需要保存客户端状态 为了实现该需求

cookie与session应运而生(最初的功能核心:保存用户状态)

cookie:服务端让客户端浏览器保存的数据(kv键值对)
session:服务端保存的关于用户相关的数据(kv键值对)
'''session的工作需要依赖于cookie'''

目前只要是需要用户登录的网站 基本都需要使用cookie

客户端浏览器也可以拒绝保存cookie

django操作cookie

视图函数必须返回HttpResponse对象

from django.shortcuts import HttpResponse,render,redirect
return HttpResponse()
return render()
return redirect()

要想操作cookie必须先产生对象,之后利用对象内置方法操作

obj1 = HttpResponse()
return obj1
obj2 = render()
return obj2
obj3 = redirect()
return obj3

设置与获取cookie

obj.set_cookie()  # 让浏览器保存cookie数据
request.COOKIES.get()  # 获取浏览器携带过来的cookie数据
obj.set_cookie(max_age\expires)  # 以秒为基准
obj.delete_cookie()

获取当前用户想要访问的地址

    request.path_info         # 仅获取url的后缀名
    request.get_full_path()   # 获取的全路径,包含问号后面的参数部分

代码练习
from django.shortcuts import render, HttpResponse, redirect

Create your views here.

from functools import wraps

校验登录装饰器

def login_auth(func):
@wraps(func) # 装饰器修复技术
def inner(request, *args, **kwargs):
# 给参数赋值获取访问之前页面的数据
target_url = request.path_info
# 先校验用户的cookie
cookie_data = request.COOKIES.get(‘name’)
if cookie_data == ‘meng’:
res = func(request, *args, **kwargs)
return res
else:
# 加上target_url可以获取登录之前访问的页面
return redirect(’/login/?target_url=%s’ % target_url)
return inner

@login_auth
def home(request):
return HttpResponse(‘登录页面该展示的内容’)

@login_auth
def index(request):
return HttpResponse(‘index页面,登录页面该展示的内容’)

@login_auth
def func(request):
return HttpResponse(‘func页面,登录页面该展示的内容’)

def login(request):
if request.method == ‘POST’:
username = request.POST.get(‘username’)
password = request.POST.get(‘password’)
if username == ‘meng’ and password == ‘123’:
# 先获取用户登录之前需要访问的页面,如果没有数据跳转到首页
target_url = request.GET.get(‘target_url’, ‘/home/’) # 如果前面没有数据,使用后面的数据
obj = redirect(target_url)
# 设置cookie
obj.set_cookie(‘name’, ‘meng’,expires=3) # expires:设置几秒丢掉cookie
# 跳转到首页
return obj
return render(request, ‘login.html’)

退出

def logout(request):
obj = redirect(’/home/’)
obj.delete_cookie(‘name’)
return obj
django操作session
request.session[key] = value # 设置session
1.django自动产生一个随机字符串
2.默认在django_session表中保存随机字符串与数据的对应关系
3.将随机字符串发送给客户端浏览器保存
sessionid:随机字符串

request.session.get(key) # 获取session
1.django自动获取浏览器发送过来的cookie数据 获取随机字符串
2.拿着随机字符串去django_session表中比对
3.如果对应上了则获取数据并解密成明文的形式

‘’’
需要记住的:
1.django默认的session失效时间>>>:两周(14天)
2.同一个计算机上一个浏览器只会有一条数据生效,当session过期的时候可能会出现多条
还有可能是不同浏览器访问,也可能出现多条数据。
‘’’

删除当前会话的所有Session数据

request.session.delete()  # 只删除浏览器数据,客户端不会删除

删除当前的会话数据并删除会话的Cookie。

request.session.flush()   # 推荐使用
这用于确保前面的会话数据不可以再次被用户的浏览器访问

设置会话Session和Cookie的超时时间

request.session.set_expiry(value)
* 如果value是个整数,session会在些秒数后失效。
* 如果value是个datatime或timedelta,session就会在这个时间后失效。
* 如果value是0,用户关闭浏览器session就会失效。
* 如果value是None,session会依赖全局session失效策略。

session的存储位置是可以自定义的

1. 数据库Session
SESSION_ENGINE = 'django.contrib.sessions.backends.db'   # 引擎(默认)
2. 缓存Session
SESSION_ENGINE = 'django.contrib.sessions.backends.cache'  # 引擎
SESSION_CACHE_ALIAS = 'default'                            # 使用的缓存别名(默认内存缓存,也可以是memcache),此处别名依赖缓存的设置
3. 文件Session
SESSION_ENGINE = 'django.contrib.sessions.backends.file'    # 引擎
SESSION_FILE_PATH = None                                    # 缓存文件路径,如果为None,则使用tempfile模块获取一个临时地址tempfile.gettempdir() 
4. 缓存+数据库
SESSION_ENGINE = 'django.contrib.sessions.backends.cached_db'        # 引擎
5. 加密Cookie Session
SESSION_ENGINE = 'django.contrib.sessions.backends.signed_cookies'   # 引擎
亚马逊测评 www.yisuping.cn
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值