spring boot之session知识点小结

本文介绍了Spring Boot中Session的基本概念,包括Session的创建、存储和生命周期。讨论了Session与Cookie的区别,强调Session由服务器管理,而Cookie存储在客户端。此外,还讲解了如何设置Session属性、超时时间以及如何利用Session监听器实现在线人数统计等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、 session简介

1. 服务器可以为每个用户浏览器创建一个会话对象(session对象),一个浏览器只能产生一个session,当新建一个窗口访问服务器时,还是原来的那个session。session中默认保存的是当前用户的信息。因此,在需要保存其他用户数据时,我们可以自己给session添加属性。session(会话)可以看为是一种标识,通过带session的请求,可以让服务器知道是谁在请求数据。

二、 session与cookie的区别和联系
1、 session是由服务器创建的,并保存在服务器上的。在session创建好之后,会把sessionId放在cookie中返回(response)给客户端。返回的代码应该是这样子的。返回的cookie是保存在客户端的。


 String sessionId = session.getId();
 Cookie cookie = new Cookie("JSESSIONID", sessionId);
 cookie.setPath(request.getContextPath());
 response.addCookie(cookie);
2、 以后的每次HTTP请求都会带着sessionId,来跟踪用户的整个会话。
3、 session的过期和超时与cookie的过期没有什么联系,都是可以分别进行设置的。但是当session或cookie中任意一方过期,那么用户就需要重新登录了。

三、 session相关
1、 session的创建@GetMapping("demo")
public void demo(HttpServletRequest request){
HttpSession sessoin=request.getSession();//这就是session的创建
session.setAttribute("username","TOM");//给session添加属性属性name: username,属性 value:TOM
session.setAttribute("password","tommmm");//添加属性 name: password; value: tommmm
System.out.println(session.geiId);
}

其中HttpSession session=request.getSession(true); //true表示如果这个HTTP请求中,有session,那么可以直接通过getSession获取当前的session,如果当前的请求中没有session,则会自动新建一个session
       HttpSession session=request.getSession(false);//false表示只能获取当前请求中的session,如果没有也不能自动创建。

2、 session的 获取属性

session.getAttribute("username");
session.getAttribute("password"); 

3、 session,cookies的超时设置

 1 在.yml里面或.xml配置文件里面 

 2 在创建session时 

 session.setMaxInactiveInterval(30*60);//以秒为单位,即在没有活动30分钟后,session将失效

四、 session的监听

监听session主要有三个接口,用这两个就够用了。

实现接口HttpSessionListener下的sessionCreated();//当session创建时。

和sessionDestroyed();//当session被销毁或超时时。

实现接口HttpSessionAttributeListener下的 attributeAdded() //当给session添加属性时

attributeRemoved();和attributeReplaced();

以下是简单的实现了在线人数统计的功能。

如果要更深刻的了解session的工作机制,多执行几次session的监听代码(可以参考一下的代码)。

package com.ets.handle;

import com.ets.controller.life.LoginController;
import com.ets.entity.LifeCustomerBase;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.CrossOrigin;

import javax.servlet.ServletContext;
import javax.servlet.annotation.WebListener;
import javax.servlet.http.*;
import java.util.Collections;
import java.util.HashSet;
import java.util.Set;

/**
 * @ClassName SessionListener
 * @Author dbh
 * @Description TODO
 * @Date 2018/12/29 10:38
 * @Version 1.0
 **/
@Slf4j
@WebListener
@CrossOrigin
@ControllerAdvice(basePackageClasses={LoginController.class})
public class SessionListener implements HttpSessionListener, HttpSessionAttributeListener {

    @Override
    public void attributeAdded(HttpSessionBindingEvent httpSessionBindingEvent) {

    }

    @Override
    public void attributeRemoved(HttpSessionBindingEvent httpSessionBindingEvent) {
        log.info("--attributeRemoved--");
    }

    @Override
    public void attributeReplaced(HttpSessionBindingEvent httpSessionBindingEvent) {

    }

    @Override
    public void sessionCreated(HttpSessionEvent event) {
        HttpSession session = event.getSession();
        ServletContext application = session.getServletContext();
        // 在application范围由一个HashSet集保存所有的session

        Set sessions = (Set) application.getAttribute("sessions");
        if (sessions == null) {
            sessions = Collections.synchronizedSet(new HashSet());
            application.setAttribute("sessions", sessions);
        }
        // 新创建的session均添加到HashSet集中
        sessions.add(session);
        log.info("---sessionCreated session.size()----"+sessions.size());
        log.info("---sessionCreated sessionid----"+session.getId());

    }

    @Override
    public void sessionDestroyed(HttpSessionEvent event) throws ClassCastException {
        HttpSession session = event.getSession();
        log.info("deletedSessionId: " + session.getId());
        ServletContext application = session.getServletContext();
        Set sessions = (Set) application.getAttribute("sessions");
        // 销毁的session均从HashSet集中移除
        sessions.remove(session);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值