SPRING BOOT踩坑——启动时让方法自动执行

本文详细解析了SpringBoot应用启动过程中,多种不同方式执行自定义代码的时机与顺序,包括实现ServletContextAware接口、ServletContextListener接口、使用@PostConstruct注解、实现ApplicationRunner和CommandLineRunner接口等方法。

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

1.实现ServletContextAware接口并重写其setServletContext方法
@Component
public class TestStarted implements ServletContextAware {
    /**
     * 在填充普通bean属性之后但在初始化之前调用
     * 类似于initializingbean的afterpropertiesset或自定义init方法的回调
     *
     */
    @Override
    public void setServletContext(ServletContext servletContext) {
        System.out.println("setServletContext方法");
    }
}
注意:该方法会在填充完普通Bean的属性,但是还没有进行Bean的初始化之前执行 

2.实现ServletContextListener接口
    /**
     * 在初始化Web应用程序中的任何过滤器或servlet之前,将通知所有servletContextListener上下文初始化。
     */
    @Override
    public void contextInitialized(ServletContextEvent sce) {
        //ServletContext servletContext = sce.getServletContext();
        System.out.println("执行contextInitialized方法");
    }
3.将要执行的方法所在的类交个spring容器扫描(@Component),并且在要执行的方法上添加@PostConstruct注解或者静态代码块执行
@Component
public class Test2 {
    //静态代码块会在依赖注入后自动执行,并优先执行
    static{
        System.out.println("---static--");
    }
    /**
     *  @Postcontruct’在依赖注入完成后自动调用
     */
    @PostConstruct
    public static void haha(){
        System.out.println("@Postcontruct’在依赖注入完成后自动调用");
    }
}
 

4.实现ApplicationRunner接口
    /**
     * 用于指示bean包含在SpringApplication中时应运行的接口。可以定义多个applicationrunner bean
     * 在同一应用程序上下文中,可以使用有序接口或@order注释对其进行排序。
     */
    @Override
    public void run(ApplicationArguments args) throws Exception {
        System.out.println("ApplicationRunner的run方法");
    }
@Component//被spring容器管理  

@Order(1)//如果多个自定义ApplicationRunner,用来标明执行顺序  

public class MyApplicationRunner implements ApplicationRunner {  

    @Override  

    public void run(ApplicationArguments applicationArguments) throws Exception {  

        System.out.println("-------------->" + "项目启动");  

        myTimer();  

    }  

4.实现CommandLineRunner接口
 

    /**
     * 用于指示bean包含在SpringApplication中时应运行的接口。可以在同一应用程序上下文中定义多个commandlinerunner bean,并且可以使用有序接口或@order注释对其进行排序。
     * 如果需要访问applicationArguments而不是原始字符串数组,请考虑使用applicationrunner。
     * 
     */
    @Override
    public void run(String... ) throws Exception {
        System.out.println("CommandLineRunner的run方法");
    }

### Spring Boot 整合 WebSocket 示例教程 #### 1. 添加依赖项 为了在Spring Boot项目中使用WebSocket,需要引入`spring-boot-starter-websocket`依赖。这可以通过修改项目的构建文件(Maven的pom.xml或Gradle的build.gradle)来完成。 对于Maven项目,在`<dependencies>`标签内加入以下代码片段: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> ``` 这段XML定义了用于支持WebSocket功能的核心库[^3]。 #### 2. 创建启动类 创建一个新的Java类作为应用程序入口点,并标注为@SpringBootApplication以便自动配置Spring上下文环境。此操作通常只需要编写少量代码即可实现基本的功能框架搭建。 ```java package com.example.demo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ``` 上述代码展示了最简单的Spring Boot应用启动方式[^4]。 #### 3. 配置WebSocket服务器端逻辑 接下来要做的就是设置好服务端接收客户端请求的具体行为模式。一般情况下会涉及到两个主要组件——`WebSocketConfigurer`接口及其子类用来声明全局性的路由规则;另一个则是具体的处理器实例负责实际的消息处理工作。 下面是一个典型的WebSocket配置器例子: ```java @Configuration @EnableWebSocket public class WebSocketConfig implements WebSocketConfigurer { @Override public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) { registry.addHandler(myWebSocketHandler(), "/ws").setAllowedOrigins("*"); } @Bean public MyWebSocketHandler myWebSocketHandler() { return new MyWebSocketHandler(); } } ``` 这里注册了一个名为`myWebSocketHandler()`的方法返回自定义的WebSocket处理器对象,并将其映射到路径`/ws`上接受来自任意源地连接尝试[^5]。 #### 4. 编写消息处理器 最后一步是设计具体的消息监听者即所谓的“handler”。此类应当继承于`TextWebSocketHandler`或其他更高级别的抽象基类之一,从而获得必要的工具方法去解析传入的数据包并作出响应动作。 ```java @Component public class MyWebSocketHandler extends TextWebSocketHandler { private final Logger logger = LoggerFactory.getLogger(MyWebSocketHandler.class); @Override protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception { String payload = message.getPayload(); logger.info("Received message from client: " + payload); // Echo back the received text to all connected clients. session.sendMessage(new TextMessage("Echo: " + payload)); } } ``` 在这个示例里每当接收到新的文本型数据帧时就会触发对应的事件回调函数执行相应的业务流程。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值