热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

django2.2操作cookie与session

文章目录一、cookie与session简介1.cookie2.session二、django操作cookie三、django操作sessiondjango中的Session配置一

文章目录

  • 一、COOKIE与session简介
    • 1. COOKIE
    • 2. session
  • 二、django操作COOKIE
  • 三、django操作session
    • django中的Session配置


一、COOKIE与session简介

1. COOKIE

由于http协议是无状态协议,即每次浏览器发来的请求,对于服务端来说,都是一个全新的请求,无法辨别该客户端之前做过哪些操作。

于是,就有了COOKIE来弥补这一缺点。COOKIE是由服务端产生并发送给客户端,然后保存在客户端的,其表现形式为一个个的键值对。之后客户端每次发送请求时,都会将COOKIE附带在请求头的COOKIE字段中发给服务器。服务端就可以通过这些COOKIE信息实现对客户端状态的识别。

举例来说,如果没有COOKIE,我们每次登录某个网站后,每打开一个需要登录的页面,就需要重新登陆一次,因为服务端并不知道你登陆过。而有了COOKIE之后,当我们第一次登录某个网站时,浏览器就会将服务端发过来的COOKIE保存,之后的请求带上这些COOKIE,服务端就可以通过COOKIE信息,辨别出目前的用户已经登陆。

ps:COOKIE是按照源(协议+域名+端口)保存的,不同的源之间无法访问对方的COOKIE。

2. session

因为COOKIE是保存在客户端的,所以很容易被骇客窃取或篡改。针对这个问题,就出现了基于COOKIE的session技术。和COOKIE类似,session通常也是键值对的形式,但保存在服务器端。

COOKIE保存一些不重要的数据;session则保存重要的数据,并将键(通常是一串随机字符串)发送一份到客户端保存为COOKIE(COOKIE键名通常为sessionid),作为和session对接的凭证。二者配合使用,实现了状态的保存,并提升了安全性。

ps:从第一次请求服务器开始,一直到关闭浏览器,这中间的过程被称之为会话

二、django操作COOKIE

视图最终要返回一个HttpResponse及其子类的对象,而操作COOKIE则需要通过这些对象来进行处理,处理完之后再由视图返回。

# 以 HttpResponse 为例
obj = HttpResponse()# 设置 COOKIE
obj.set_COOKIE('key', valie)# 获取 COOKIE
request.COOKIES.get('key')# 删除 COOKIE
obj.delete_COOKIE('key')# 设置有效时长为3秒
obj.set_COOKIE('key', valie, max_age=3)

三、django操作session

django操作session,默认会将session信息保存到数据库中,有效期为14天

# 设置 session
request.session['key'] = value# 获取 session
request.session.get('key')# 删除 session
request.session.delete()
# 删除当前 session 和客户端会话 COOKIE
request.session.flush()# 设置有效时长为3秒
request.session.set_expiry(3)
# 设置到规定时间后失效
request.session.set_expiry(python时间对象)
# 设置有效时长为全局会话过期策略,默认为14天
request.session.set_expiry(None)
# 设置有效时长为会话时长,浏览器关闭,session 失效
request.session.set_expire(0)

  • 设置session时,django的内部操作:

    1 django自动生成一个随机字符串;

    2 将字符串和对应的数据保存到django_session表中;

    3 将随机字符串发送给客户端,保存为COOKIE,键名为sessionid。

  • 获取session时,django的内部操作:

    1 从浏览器请求中获取sessionid对应的随机字符串;

    2 使用该字符串到django_session表中获取对应的数据;

    3 如果找到,就将数据以字典形式封装到request.session中;如果没找到,就将None以字典形式封装到request.session中。


django中的Session配置


  • 数据库Session:

    SESSION_ENGINE = 'django.contrib.sessions.backends.db' # 引擎(默认)

  • 缓存Session:

    SESSION_ENGINE = 'django.contrib.sessions.backends.cache' # 引擎SESSION_CACHE_ALIAS = 'default' # 使用的缓存别名(默认内存缓存,也可以是memcache),此处别名依赖缓存的设置

  • 文件Session:

    SESSION_ENGINE = 'django.contrib.sessions.backends.file'
    # 引擎SESSION_FILE_PATH = None
    # 缓存文件路径,如果为None,则使用tempfile模块获取一个临时地址tempfile.gettempdir()

  • 缓存+数据库:

    SESSION_ENGINE = 'django.contrib.sessions.backends.cached_db' # 引擎`

  • 加密COOKIE Session:

    SESSION_ENGINE = 'django.contrib.sessions.backends.signed_COOKIEs' # 引擎`

  • 其他公用设置项:

    SESSION_COOKIE_NAME = "sessionid"
    # Session的COOKIE保存在浏览器上时的key,即:sessionid=随机字符串(默认)
    SESSION_COOKIE_PATH = "/" # Session的COOKIE保存的路径(默认)
    SESSION_COOKIE_DOMAIN = None # Session的COOKIE保存的域名(默认)
    SESSION_COOKIE_SECURE = False
    # 是否Https传输COOKIE(默认)
    SESSION_COOKIE_HTTPONLY = True
    # 是否Session的COOKIE只支持http传输(默认)
    SESSION_COOKIE_AGE = 1209600
    # Session的COOKIE失效日期(2周)(默认)
    SESSION_EXPIRE_AT_BROWSER_CLOSE = False
    # 是否关闭浏览器使得Session过期(默认)
    SESSION_SAVE_EVERY_REQUEST = False
    # 是否每次请求都保存Session,默认修改之后才保存(默认)


推荐阅读
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • Request对象和Response对象request:(请求)当一个页面被请求时,Django就会创建一个包含本次请求原信息的HttpRequest对象。Djang ... [详细]
  • SQLiLabs靶场的介绍、下载与安装
    介绍SQLi-Labs是一个专业的SQL注入练习平台下面的测试场景都支持GET和POST两种注入方式:1.报错注入(联合查询)1)字符型2)数字型2.报错注入(基于 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • PHP反射API的功能和用途详解
    本文详细介绍了PHP反射API的功能和用途,包括动态获取信息和调用对象方法的功能,以及自动加载插件、生成文档、扩充PHP语言等用途。通过反射API,可以获取类的元数据,创建类的实例,调用方法,传递参数,动态调用类的静态方法等。PHP反射API是一种内建的OOP技术扩展,通过使用Reflection、ReflectionClass和ReflectionMethod等类,可以帮助我们分析其他类、接口、方法、属性和扩展。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • 【爬虫】关于企业信用信息公示系统加速乐最新反爬虫机制
    ( ̄▽ ̄)~又得半夜修仙了,作为一个爬虫小白,花了3天时间写好的程序,才跑了一个月目标网站就更新了,是有点悲催,还是要只有一天的时间重构。升级后网站的层次结构并没有太多变化,表面上 ... [详细]
  • 前言:关于跨域CORS1.没有跨域时,ajax默认是带cookie的2.跨域时,两种解决方案:1)服务器端在filter中配置详情:http:blog.csdn.netwzl002 ... [详细]
  • 渗透测试基础bypass绕过阻挡我们的WAF(下)
    渗透测试基础-bypass ... [详细]
  • 找到JDK下载URL当然去官网找了。目前最新的1.8的下载URL(RPM)如下:http:download.oracle.comotn-pubjavajdk8u161-b122f3 ... [详细]
  • Java大文件HTTP断点续传到服务器该怎么做?
    最近由于笔者所在的研发集团产品需要,需要支持高性能的大文件http上传,并且要求支持http断点续传。这里在简要归纳一下,方便记忆 ... [详细]
  • 注:根据Qt小神童的视频教程改编概论:利用最新的Qt5.1.1在windows下开发的一个小的时钟程序,有指针与表盘。1.Qtforwindows开发环境最新的Qt已经集 ... [详细]
author-avatar
迷路的小孩w
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有