Django的Session

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_42233629/article/details/84202291

Session简介

Cookie的缺点
1.Cookie保存在浏览器端,无法存一些机密的信息,因为能看到,不安全,
2.Cookie长度不能超过4096个字节
在这里插入图片描述
Session
1.保存在服务器端的键值对,所以没有长度的限制,可以存到数据库或文件。
session缺点:如果用户1亿,就要存1亿个字典,由于硬盘空间有限,可以设置超时了就删
session原理,拿到key才能打开后端存的对应的值
在这里插入图片描述

Django中Session相关用法

  • 获取,设置, 删除Session中的数据
    request.session[‘k1’] 新增键值对
    request.session.get(‘k1’, None) 获取值
    request.session.setdefault(‘k1’, 123): 如果存在则不设置,否则设置
    del request.session(‘k1’) :删除指定的键值对
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    取值时的步骤
    在这里插入图片描述

  • 所有键,值,键值对
    request.session.keys() : 所有的键
    request.session.values(): 所有的值
    request.session.items()
    request.session.iterkeys() :获取可迭代的键
    request.session.itervalues()
    request.session.iteritems()

  • 当前请求的key是什么
    request.session.session_key: 数据库中的sessionkey

  • 将所有Session失效日期小于当前日期的数据删除
    request.session.clear_expired()
    如设置0点自动把已经过了失效时间的数据清除
    在这里插入图片描述

  • 检查会话session的key在数据库中是否存在
    request.session.exists(‘session_key’)

  • 删除当前会话的所有Session数据
    request.session.delete(): 注销时用到,在后端删除当前请求的session数据
    在这里插入图片描述

  • 删除当前会话数据并删除会话的Cookie
    request.session.flush():删除并让cookie失效

  • 设置超时时间
    request.sesssion.set_expiry(value)
    request.session.set_expiry(value)
    value–>整数,session会在些秒后失效
    value–>datatime或timedelta,session会在这个时间后失效
    value–>0,用户关闭浏览器session会失效
    value–>None,session会依赖全局session失效策略

在这里插入图片描述

参考资料
django官网对session的描述
老师博客

展开阅读全文

没有更多推荐了,返回首页