Spring-Boot 监听器

监听器Listener

概述

web监听器是servlet中特殊的类,能够帮助开发着监听web中的一些特定事件。

监听器的什么?

  • ServletContext – application
  • HttpSession - session
  • ServletRequest - request

监听器监听就是:拥有作用域的对象。而这个作用域的对象分别都有相同的方法

  • setAttribute
  • getAttribute
  • removeAttribute

不论三每个那种作用域只要调用setAttribute或者getAttribute或者删除removeAttribute就会进入到监听器的对应的方法中进行处理相应的逻辑。

应用场景

  • 初始化上下文,比如:spring容器的初始化,文件的解析
  • 会话的监听,比如:在线人数
    • demo版本
  • 监听客户的请求信息,比如:对某一个用户进行数据干预。
    • 直播,对平台中某些用户资源倾斜。

Springboot如何定义和注册监听器

监听ServletContext对象

package com.kuangstudy.config.listener;

import com.kuangstudy.pojo.User;
import com.kuangstudy.service.UserService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationListener;
import org.springframework.context.annotation.Lazy;
import org.springframework.context.event.ContextRefreshedEvent;
import org.springframework.stereotype.Component;

import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

@Component
@Slf4j
public class ServletContextListener2 implements ServletContextListener {

    @Override
    public void contextInitialized(ServletContextEvent sce) {
       log.info("ServletContextListener2 --- > 监听器进来了.....");
    }

    @Override
    public void contextDestroyed(ServletContextEvent sce) {
        log.info("删除方法 ---- 监听器进来了.....");
    }
}

用来做:springioc容器的初始化使用的。

web.xml

<context>
    <context-name>contextConfigLocation</context-name
    <context-value>classpath:bean.xml</context-name
</context>

等价于

application.setAttribute("configurationLocation","classpath:bean.xml")

监听Http会话session对象

使用场景:监听session对象,以统计当前web网站在线用户的总数据量。如下:

1:创建一个session会话监听器,实现HttpSessionLisintener接口:

package com.kuangstudy.config.listener;

import com.kuangstudy.pojo.User;
import com.kuangstudy.service.UserService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationListener;
import org.springframework.context.event.ContextRefreshedEvent;
import org.springframework.stereotype.Component;

import javax.servlet.ServletContext;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;

@Component
public class LoginSessionListener implements HttpSessionListener {

    // 1: 定义一个在线人数的计数器
    public static Integer count = 0;

    @Override
    public void sessionCreated(HttpSessionEvent se) {
        System.out.println("新用户上线了...");
        count++;
        ServletContext application = se.getSession().getServletContext();
        application.setAttribute("personcount", count);
    }

    @Override
    public void sessionDestroyed(HttpSessionEvent se) {
        System.out.println("用户下线了...");
        count--;
        ServletContext application = se.getSession().getServletContext();
        application.setAttribute("personcount", count);
    }
}

2:定义登录,退出,查询在线人数

package com.kuangstudy.web;

import com.kuangstudy.pojo.User;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

@RestController
public class LoginController {

    @GetMapping("/count/onelineuser")
    public String getOnlinePersoncount(HttpServletRequest request) {
        Integer personcount = (Integer) request.getServletContext().getAttribute("personcount");
        return  (personcount == null ? "0" : personcount + "");
    }

    @GetMapping("/logined")
    public String logined(HttpSession session) {
        // 相同的session信息,它的sessionid是一致,监听器只会进入一次。
        session.setAttribute("user", new User(1L, "yykk", "zhangsan"));
        return "success";
    }

    @GetMapping("/logout")
    public String logout(HttpSession session) {
        // session.invalidate --- 会进入到 sessionDestroyed
        session.invalidate();
        return "success";
    }
}

分别访问:

http://localhost:8987/count/onelineuser ----- 查看在线人数

http://localhost:8987/logined ------登录

http://localhost:8987/logout ---- 退出

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: rocketmq-spring-boot-starter是一个基于Spring Boot框架的RocketMQ客户端启动器,可以方便地在Spring Boot应用中集成RocketMQ消息队列服务。它提供了一些自动配置和便捷的注解,使得开发者可以快速地使用RocketMQ进行消息的发送和消费。同时,它还支持RocketMQ的高可用、负载均衡、顺序消息等特性。 ### 回答2: RocketMQ是一个分布式的消息中间件系统,是由阿里巴巴公司开发和维护的。RocketMQ在分布式系统中能够提供高可用、高性能、可靠的消息服务。由于RocketMQ经历了多年的实践和迭代,因此它拥有了广泛的用户群体和丰富的功能特性。而RocketMQ-Spring-Boot-Starter就是为了更加方便RocketMQ在Spring Boot应用中的使用而开发的。下面就来介绍一下RocketMQ-Spring-Boot-Starter的使用和特点。 RocketMQ-Spring-Boot-Starter能够非常方便地集成RocketMQ消息系统到Spring Boot应用中。它提供了很多的配置选项,能够以最少的配置来完成RocketMQ的使用。在使用过程中,只需引入相应的依赖,然后在配置文件中添加配置即可。在消息生产者方面,只需要编写一个简单的就可以实现发送消息的操作。在消息消费者方面,只需要编写一个监听器就可以实现消息的接收和处理。而且RocketMQ-Spring-Boot-Starter提供了一些常用的RocketMQ操作,如日志记录、重试机制、事务消息等等,可以方便地进行日常开发和维护。 RocketMQ-Spring-Boot-Starter还有一些其他的特点。比如,它支持集成RocketMQ的多个版本,可以兼容不同版本的应用。同时,RocketMQ-Spring-Boot-Starter还支持多种序列化方式,如JSON、Protobuf等,可以满足不同的应用场景要求。而且,RocketMQ-Spring-Boot-Starter还提供了自定义的序列化插件和编码器,可以进一步满足自定义需求。 总之,RocketMQ-Spring-Boot-Starter是一个强大而实用的RocketMQ消息中间件集成框架。它可以有效地提高RocketMQ消息中间件的开发效率和应用性能,为开发人员提供更好的开发和维护体验。 ### 回答3: rocketmq-spring-boot-starter是一个开源项目,基于Spring Boot框架及Apache RocketMQ消息队列实现的一款快速构建分布式应用的工具,使得RocketMQ在Spring Boot框架下快速应用成为了一件简单的事情。该项目可以避免使用RocketMQ时需要手动编写大量重复的配置代码,还可以便捷地实现RocketMQ的消息发送和消费。 在使用rocketmq-spring-boot-starter的时候,用户只需要简单配置相关配置项,就可以实现轻松的RocketMQ消息队列的使用。通过整合Spring Boot消息组件让开发者使用RocketMQ变得更加方便和容易。rocketmq-spring-boot-starter将RocketMQ客户端的配置和实例化放在自己的工程内,并将这些配置文件和实例自动注入到Spring Boot的应用环境中,从而让使用者可以直接使用aop来使用RocketMQ的消息发送和消费功能。 此外,该项目还具有简单易用、高可靠、无侵入等特点,方便了开发者的代码管理和维护。用户可以少写一些繁琐重复的代码,只需在配置文件中配置相关项,就可以快速完成RocketMQ的使用,并利用Spring Boot的依赖注入,让代码结构更加简洁清晰,可维护性更高。 总之,rocketmq-spring-boot-starter的出现让使用RocketMQ消息队列的开发者可以更加轻松高效地进行消息处理,而且这个项目也在GitHub上得到了广泛的使用和支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值