首页 > 其他分享 >cookie与session

cookie与session

时间:2023-10-22 12:12:49浏览次数:27  
标签:浏览器 request django session cookie 服务端

cookie
服务端保存在客户端浏览器上的信息都可以称之为cookie
它的表现形式一般都是k:v键值对(可以有多个)
session
数据是保存在服务端的并且它的表现形式一般也是k:v键值对(可以有多个)
总结:
1.cookie就是保存在客户端浏览器上的信息
2.session就是保存在服务端上的信息
3.session是基于cookie工作的(其实大部分的保存用户状态的操作都需要使用到cookie)

Cookie操作

# 如果你想要操作cookie,你就不得不利用obj对象
obj1 = HttpResponse()
return obj1

obj2 = render()
return obj2

obj3 = redirect()
return obj3
"""
设置cookie
	obj.set_cookie(key,value)
	eg:obj.set_cookie('username', 'tiger')
获取cookie
	request.COOKIES.get(key)
	eg:request.COOKIES.get('username')
设置cookie超时时间
	max_age
	expires
	两者都是设置超时时间的 并且都是以秒为单位
    需要注意的是 针对IE浏览器需要使用expires
    eg:obj.set_cookie('username', 'tiger', max_age=60)

主动删除cookie(注销功能)
	obj.delete_cookie(key)
	eg:obj.delete_cookie('username')
"""

session操作(按照字典操作即可)

"""
session数据是保存在服务端的(存在哪? ),给客户端返回的是一个随机字符串
	sessionid:随机字符串

存在服务端哪?
1.在默认情况下操作session的时候需要django默认的一张django_session表
	数据库迁移命令
		django会自己创建很多表	django_session就是其中的一张
		

django默认session的过期时间是14天
	但是你也可以人为的修改它
	

设置session	
request.session['key'] = value

获取session
request.session.get('key')

设置过期时间
request.session.set_expiry()
	括号内可以放四种类型的参数
		1.整数				  多少秒
		2.日期对象			  到指定日期就失效
		3.0			          一旦当前浏览器窗口关闭立刻失效
		4.不写				  失效时间就取决于django内部全局session默认的失效时间14天

清除session	
	request.session.delete()  	# 只删服务端的 客户端的不删
	request.session.flush()  	# 浏览器和服务端都清空(推荐使用)
"""

def set_session(request):
    request.session['hobby'] = 'study'
    """
    内部发生了哪些事
        1.django内部会自动帮你生成一个随机字符串
        2.django内部自动将随机字符串和对应的数据存储到django_session表中
            2.1先在内存中产生操作数据的缓存
            2.2在响应结果django中间件的时候才真正的操作数据库
        3.将产生的随机字符串返回给客户端浏览器保存
    """
    return HttpResponse('好好学习 天天向上!')


def get_session(request):
    print(request.session.get('hobby'))
    """
    内部发送了那些事
        1.自动从浏览器请求中获取sessionid对应的随机字符串
        2.拿着该随机字符串去django_session表中查找对应的数据
        3.
            如果比对上了 则将对应的数据取出并以字典的形式封装到request.session中
            如果比对不上 则request.session.get()返回的是None
    """
    return HttpResponse('哈哈哈!')

标签:浏览器,request,django,session,cookie,服务端
From: https://www.cnblogs.com/piggthird/p/17780238.html

相关文章

  • 5种类型的Session
    Django默认支持Session,内部提供了5种类型的Session供开发者使用1.数据库SessionSESSION_ENGINE='django.contrib.sessions.backends.db'#引擎((默认)2.缓存SessionSESSION_ENGINE='django.contrib.sessions.backends.cache'#引擎SESSION_CA......
  • nginx首次安装sticky模块-cookie保持会话
    首次安装nginx:(下一篇文章是nginx添加sticky模块)yuminstall-ypcre*openssl*gccgcc-c++make--安装编译环境wgethttps://bitbucket.org/nginx-goodies/nginx-sticky-module-ng/get/08a395c66e42.zip--下载sticky模块nginx-v--查看Nginx版本,因为要下载和yum安装nginx......
  • nginx添加sticky模块-cookie保持会话
    环境nginx1.8.0 centos6.X sticky:1.2.5 wgethttps://bitbucket.org/nginx-goodies/nginx-sticky-module-ng/get/master.tar.gzcookie负载均衡相比iphash来比其中一个特点比较明显:内网nat用户的均衡。而iphash无法做到。yuminstallopenssl openssl-devel先停止ngi......
  • 谈谈selenium中的cookie操作
    实例演示以登录网易云音乐为例分两步走获取cookiesfromseleniumimportwebdriverfrompprintimportpprintdriver=webdriver.Chrome()driver.maximize_window()driver.get('https://music.163.com/')driver.delete_all_cookies()#此处只是演示api,可以不写的inpu......
  • java项目实践-cookie-session-day18
    目录1.cookie2.session3.servletcontext4.servletConfig1.cookiecookie在客户端(浏览器)中保持http状态的信息技术本质是浏览器缓存每次发请求的时候在请求头中带给服务端常见的应用场景:实现7天免登录浏览器F12request.setCharacterEncoding("utf-8");......
  • Redis代替session需要考虑的问题
    Redis代替session需要考虑的问题◆选择合适的数据结构◆选择合适的key◆选择合适的存储粒度......
  • 由Django-Session配置引发的反序列化安全问题
    漏洞成因漏洞成因位于目标配置文件settings.py下关于这两个配置项SESSION_ENGINE:在Django中,SESSION_ENGINE 是一个设置项,用于指定用于存储和处理会话(session)数据的引擎。SESSION_ENGINE 设置项允许您选择不同的后端引擎来存储会话数据,例如:数据库后端 (django.contrib.sessions.b......
  • Redis实现登录(基于session)
    Redis实现登录(基于session)拦截器:实现多模块用户登录的校验代码:创建拦截器publicclassLoginInterceptorimplementsHandlerInterceptor{@OverridepublicbooleanpreHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler)throwsExcept......
  • 彻底搞定Cookie、Session、Token的区别
    Cookie、Session、Token是Web开发中经常涉及到的三种概念。之前我们通过《用户隐私是如何通过Cookie泄漏的》一文,了解了Cookie的起源、作用以及如何被互联网大厂们滥用而失控的。那么,Session和Token又是啥呢?它们与Cookie的区别又是啥呢?这里DD给大家找了一个不错的讲解视频,该视频结......
  • laravle cookie
    Laravel是一个流行的PHP框架,提供了方便的缓存功能来加速应用程序。有时候我们需要更改缓存值,本文将介绍如何在Laravel中更改缓存值。一、了解Laravel缓存在Laravel中,我们使用Cache类来操作缓存。Laravel支持多种缓存驱动,包括文件缓存、数据库缓存、Redis缓存等。......