会话管理(session)

简介: 会话技术分类cookie技术会话数据保存在浏览器客户端session技术会话数据保存在服务端coolie技术技术核心cookie类(来自servlet):用于存储会话数据1.

会话技术分类

  • cookie技术

会话数据保存在浏览器客户端

  • session技术

会话数据保存在服务端

coolie技术

  • 技术核心

cookie类(来自servlet):用于存储会话数据
1.构造cookie对象:
Cookie(java.lang.String name ,java.lang.String value)
2.设置Cookie

void setPath(java.lang.String url)设置Cookie的有效访问路径

cookie.setPath(/绝对路径);

void setMaxAge(int expiry)设置Cooike的有效时间

正整数:表示cookie数据保存浏览器的缓存目录(硬盘中),数值表示保存的时间
负整数:表示cookie数据保存浏览器的内存中,浏览器关闭cookie就丢失
零:表示删除同名的cookie数据

void setValue(java.lang.String newValue)设置Cookie的值

3.发送Cookie到浏览器端保存
void response.addCookie(Cookie cookie);发送Cookie
4.服务器接受Cookie
Cookie request.getCookies();接受Cookie

  • 小节

cookie可以保存数据,但是cookie有条件限制,比如发送的内容只能是非中文的数据

sesion技术核心

HttpSession类:用于保存会话数据

  • 创建或者得到session对象
    HttpSession()
    HttpSesion(boolean create)
  • 设置session对象
    void setmaxInactiveInterval(int interval):设置session有效时间
    void invalidate():销毁session
    java.lang.String getId():得到session的编号
  • 保存会话的数据到session对象
    void setAttribute(java.lang.String , java.lang.Object value):保存数据
    java.lang.Object getAttribute(java.lang.String name):获取数据
    void removeAttribute(java.lang.String name):清除数据

session原理

问题:服务器能够识别不同的浏览者
前提:从那个session域对象保存数据,就必须从哪个域对象取出

  • 总结:
    代码解读:HttpSeeesion session = request.getSession();
    • 创建session对象,给session对象分配一个唯一的ID,叫JSESSIONID
    • 把JSESSIONID作为Cookie的值发送给浏览器保存
    • 第二次访问的时候,浏览器带着JSESSSIONID的cookie访问服务器
    • 服务器得到JSESSIONID,在服务器的内存中搜索是否存放对应的编号的session对象
    • 如果找到对应编号的session对象,直接返回该对象
    • 如果找不到对应的编号session对象,创建新的session对象,继续走1的流程
      结论:通过JSESSION的cookie值在服务器找session对象

session细节

  • java.lang.String getId():得到session的编号
  • 两个getSession方法

getSesstion(true)/getSession(): 创建或得到session对象。没有匹配的session编号,自动创建新的session对象
getSession(false):得到session对象。没有匹配的session编号,返回null

  • void setMaxInactivelnterval(int interval):设置session的有效时间

session对象的销毁时间:

  • 默认情况30分钟服务器自动回收
  • 修改回收的时间(过期时间)单位:秒

修改回收的时间
session.setMaxInactiveInterval(20);

  • 全局修改session有效时间

< !--修改session的有效时间:分钟-->

<session-config>
<session-timeout>1</session-timeout>
</session-config>
  • 手动去销毁session的对象

void invalidate() 手动销毁session对象

  • 如何避免浏览器的JSEEIONID的cookie随着浏览器关闭而丢失的问题
/**
*手动发送一个硬盘保存的cookie给浏览器
*/
Cookie c = new Cookie("JCOOKIEID",session.getId());
c.setMaxAge(60*60);  //保存一小时
response.addCookie(c);

总结

  • 会话管理:浏览器和服务器会话过程中的产生的会话数据管理
  • Cookie技术:new Cookie ("name","value")
    response.addCookie(cookie);
    request.getCookies()
  • Session 技术
    request.getSession();
    setAttribute("name","会话数据");
    getAttribute("会话数据");
相关文章
|
4月前
|
存储 NoSQL Java
什么是Cookie与Session之Session详解
什么是Cookie与Session之Session详解
38 0
|
4月前
|
XML 缓存 Java
Shiro - 会话管理与SessionDao持久化Session
Shiro提供了完整的企业级会话管理功能,不依赖于底层容器(如web容器tomcat),不管JavaSE还是JavaEE环境都可以使用,提供了会话管理、会话事件监听、会话存储/持久化、容器无关的集群、失效/过期支持、对Web 的透明支持、SSO 单点登录的支持等特性。
47 0
|
7月前
|
应用服务中间件 API
Session 会话
Session 会话
65 0
|
8月前
|
安全 Java 数据安全/隐私保护
SpringSecurity-10-Session会话管理
SpringSecurity-10-Session会话管理
74 0
|
10月前
会话保持技术:cookie、session
1.概述 会话保持技术的出现是因为HTTP 是一个无状态的协议,这一次请求和上一次请求是没有任何关系的,互相无法感知,上一次请求干了什么?这一次请求完全不知道,会话保持技术就是为了以一种第三方的设计实现http请求之间的联系,让请求之间能够相互感知。 目前的两大会话保持技术:
70 0
|
11月前
|
存储 NoSQL Java
Spring Session - Cookie VS Session VS Token 以及 Session不一致问题的N种解决方案
Spring Session - Cookie VS Session VS Token 以及 Session不一致问题的N种解决方案
115 0
|
存储 前端开发
Servlet【 ServletAPI中的会话管理Cookie与Session】
Servlet【 ServletAPI中的会话管理Cookie与Session】
Servlet【 ServletAPI中的会话管理Cookie与Session】
|
应用服务中间件 容器
Shiro配置cookie以及共享Session和Session失效问题
Shiro配置cookie以及共享Session和Session失效问题
344 1
|
缓存 安全 数据安全/隐私保护
会话管理
会话管理
252 0