会话机制 Cookie and Session

本文详细介绍了Cookie的工作原理及其在Web应用中的作用,并深入探讨了Session的存储方式及其实现机制,包括如何通过HttpServletRequest对象获取Session,以及Session的两种主要存储方式。

Cookie 原理:

  Cookies是一个存放cookie文件(如图所示:)

Session(会话)

原理: 

  通过HttpServletRequest的对象来获取session

  HttpSession session = request.getSession();

  getSession(true)

  --如果在本次请求之前有session对象,直接拿到session对象

  --如果本次请求之前没有session对象,创建一个新的session对象

  getSeeion(false);

  --如果在本次请求之前有session对象,直接拿到session对象

  --如果本次请求之前没有session对象,返回null

  验证用户登录是否超时会使用getSession(false)

session 存储的两种方式:

  1.使用cookie来存储jsessionId

    将jsessionId传递给服务器获取session(默认)

    (方式简洁,客户端启动cookie)

  2.使用response.encodeURL("请求地址")

    这个方法来进行url的重写将jsessionId通过url参数形式传递给服务器,从而得到session。

  给一个浏览器的窗口(以及他的子窗口)拥有一个session。

  session 相当于Map<String,Object>

  通过HttpSession.getAttribute(String Key) 取得session 中的值,通过HttpSession.setAttribute(String Key , Object value)赋值。

多次给同一个key赋值,最后一次将之前的值覆盖掉。

转载于:https://www.cnblogs.com/xuewuzhijing95hao/p/7307362.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值