栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

会话技术(Cookie和Session)

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

会话技术(Cookie和Session)

文章目录

一、会话技术是什么?1.cookie

1.概述2.规范3.常见问题4.常用API 2.Session

1.概述2.常见问题3.特点 4. cookie和Session的区别

一、会话技术是什么?

会话技术有两种:一种是通讯信息存于客户端(通常为浏览器)的cookie技术,一种为通讯信息存于服务器的Session技术。

1.cookie 1.概述

cookies 可以简单的理解为服务器暂存在你浏览器中的一些信息文件,它将你在网站上所输入的一些内容,或者一些选项记录下来,当下一次你访问同一个网站的时候,服务器就会主动去查询这个cookie资料,如果存在的话,将会根据其中的内容,提供一些特别的功能,例如记住账号密码等

总结一下就是:
网页之间的交互是通过HTTP协议传输数据的,而Http协议是无状态的协议 (数据提交后,浏览器和服务器的链接就会关闭,在此交互的时候 需要重新建立新的连接)
服务器无法确认用户的信息,于是给每一个用户发一个通行证,通过此确认用户的信息

只存储少量的不太敏感的数据

2.规范

cookie大小上限为4KB;一个服务器最多在客户端浏览器上保存20个cookie;一个浏览器最多保存300个cookie; 3.常见问题

一次可不可以发送多个cookie?

答案是可以,创建多个cookie对象,使用response调用多次addcookie方法发送cookie即可 cookie在浏览器中保存多长时间?

默认情况下,当浏览器关闭后,cookie数据被销毁。想要持久化储存需要调用 setMaxAge(int seconds) 方法

正数:将cookie数据写到硬盘的文件中持久化存储,int值为cookie存活时间。负数:默认值零:删除cookie信息 cookie能不能存中文?

在tomcat8之前cookie中不能直接存储中文数据,需要将中文数据转码 --一般采用URL编码URLEncoder.encode()。在tomcat8之后,cookie支持中文数据,但特殊字符仍然不支持,建议使用URL编码,URL解码URLDecoder.decode() cookie共享问题?

假设在一个tomcat服务器中,部署了多个web项目,那么在这些web项目中cookie能不能共享

默认情况下的话cookie不能共享需要共享需要调用setPath(String path):设置cookie的获取范围,默认情况下设置当前的虚拟目录,如果要共享则可以加path设置为"/"。 不同的tomcat服务器间cookie共享问题?

通过setDomain(String path)方法实现,如果一级域名相同,那么多个服务器之间cookie可以共享。举例:tieba.baidu.com 和 news.baidu.com中cookie可以共享。 4.常用API

  //用于在其响应头中增加一个相应的Set-cookie头字段
  addcookie
  ​
  //用于获取客户端提交的cookie
  Getcookie
      
  //该方法设置与 cookie 关联的值。
  setValue
  ​
  //该方法获取与 cookie 关联的值。
  getValue
  ​
  //该方法设置 cookie 过期的时间(以秒为单位)。如果不这样设置,cookie只会在当前 session 会话中持续有效。
  setMaxAge
  ​
  //该方法返回 cookie 的最大生存周期(以秒为单位),默认情况下,-1 表示 cookie 将持续下去,直到浏览器关闭
  getMaxAge
  ​
  //该方法设置 cookie 适用的路径。如果您不指定路径,与当前页面相同目录下的(包括子目录下的)所有 URL 都会返回 cookie。
  setPath
  ​
  //该方法获取 cookie 适用的路径。
  getPath
  ​
  //该方法设置 cookie 适用的域
  setDomain
  ​
  //该方法获取 cookie 适用的域
  getDomain
2.Session 1.概述

Session是另一种记录浏览器状态的机制,cookie保存在浏览器中,Session保存在服务器中。用户使用浏览器访问服务器的时候,服务把用户的信息,以某种形式记录在服务器,这就是Session

为何使用Session因为Session可以存储对象,cookie只能存储字符串可以解决很多cookie解决不了的问题

Session的实现时依赖cookie的

2.常见问题

当客户端关闭后,服务器不关闭,两次获取的Session是否为同一个?

默认情况下不是。如果需要相同,则可以创建cookie,键为JSESSIONID,设置最大存活时间,让cookie持久化保存

	cookiec=newcookie("JSESSIONID",session.getId());
	c.setMaxAge(60*60);
	response.addcookie(c);

客户端不关闭,服务器关闭后,两次获取的Session时同一个吗?

不是同一个,但是要确保数据不丢失

Session的钝化:在服务器正常关闭之前,将Session对象系列化到硬盘上Session的活化:在服务器启动后,将Session文件转化为内存中的Session对象即可 Session什么时候被销毁?

服务器关闭Session对象调用invalidate()Session默认失效时间30分钟已过

修改失效时间

			
					// 单位分钟
			        30 
			
3.特点

session用于存储一次会话的多次请求的数据,存在服务器端session可以存储任意类型,任意大小的数据 4. cookie和Session的区别

Session存储数据在服务器端,cookie在客户端Session没有数据大小限制,cookie有Session数据安全,cookie相对安全

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/750905.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号