目录
  • springboot 项目启动之后执行自定义方法的两种方式
    • 方式一 实现 commandlinerunner 接口
    • 方式二 实现 applicationrunner 接口
  • springboot 项目启动后执行某些自定义代码

    springboot 项目启动之后执行自定义方法的两种方式

    在测试配置中心的配置时,想在项目启动成功之后打印配置项,然后需要执行自定义的类

    一般项目中也会在这个地方进行初始化数据的一些操作

    方式一 实现 commandlinerunner 接口

    自定义类并实现 commandlinerunner 接口,实现run()方法,需要执行的语句就放在 run() 方法中

    例:

    @component
    @order(1)  // 控制类执行的顺序越小越靠前
    public class startinitializer implements commandlinerunner {
        @override
        public void run(string... args) throws exception {
            system.out.println("项目启动,执行 commandlinerunner 实现类的方法");
        }
    }

    方式二 实现 applicationrunner 接口

    自定义类并实现 applicationrunner 接口,实现run()方法,需要执行的语句就放在 run() 方法中

    例:

    @component
    @order(2) // 控制类执行的顺序越小越靠前
    public class appinitializer implements applicationrunner {
        @override
        public void run(applicationarguments args) throws exception {
            system.out.println("项目启动,执行 applicationrunner 实现类的方法");
        }
    }

    二者区别

    区别在于实现方法 run() 中的参数类型不一样

    实现 applicationrunner 接口的 run() 方法参数类型为: applicationarguments

    实现 commandlinerunner 接口的 run() 方法参数类型为: string…

    实现效果

    springboot 项目启动后执行某些自定义代码

    springboot给我们提供了两种“开机启动”某些方法的方式:applicationrunner和commandlinerunner。

    这两种方法提供的目的是为了满足,在项目启动的时候立刻执行某些方法。我们可以通过实现applicationrunner和commandlinerunner,来实现,他们都是在springapplication 执行之后开始执行的。

    commandlinerunner接口可以用来接收字符串数组的命令行参数,applicationrunner 是使用applicationarguments 用来接收参数的

    代码示例

    @component//被spring容器管理
    @order(1)//如果多个自定义applicationrunner,用来标明执行顺序
    public class myapplicationrunner implements applicationrunner {
        @override
        public void run(applicationarguments applicationarguments) throws exception {
            system.out.println("-------------->" + "项目启动,now=" + new date());
            mytimer();
        }
        public static void mytimer(){
            timer timer = new timer();
            timer.schedule(new timertask() {
                @override
                public void run() {
                    system.out.println("------定时任务--------");
                }
            }, 0, 1000);
        }
    }
    

    执行结果

    2018-02-08 14:10:16.490  info 10236 — [           main] s.b.c.e.t.tomcatembeddedservletcontainer : tomcat started on port(s): 8081 (http)
    ————–>项目启动,now=thu feb 08 14:10:16 cst 2018
    ——定时任务——–
    2018-02-08 14:10:16.497  info 10236 — [           main] com.mlxs.springboot01.web.mainapp        : started mainapp in 5.595 seconds (jvm running for 6.334)
    ——定时任务——–
    ——定时任务——–
    ——定时任务——–
    ——定时任务——–
    ——定时任务——–
    ——定时任务——–

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持www.887551.com。