quratz 中的job 监听器listener 中获取spring容器中的bean

quratz 中的job 监听器listener 中获取spring容器中bean

我们知道 由于listener 启动会先于spring 容器 况且 quratz 中的bean 是独立于spring外运行的 也就是说 spring把创建bean 的生命周期权限托管给了quratz 所以要想在job 或者job 的listener 中注入spring 的bean 肯定是不行的 但是我们可以使用别的方法。下面我写一个自己认为最简单的方法:

先创建一个spring 的SpringUtil 的工具类 ,该工具类主要是利用实现了ApplicationContextAware 接口 利用set 方法 先实例化一个ApplicationContext 然后就可以获取对应的bean源码如下

源码 注意 前提别忘记把该工具类交给spring 管理

package com.iflytek.quartz.util;

import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;

@Component
public class SpringUtil implements ApplicationContextAware{

    private static ApplicationContext applicationContext;

    @Override
    public  void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        if(SpringUtil.applicationContext == null) {
            SpringUtil.applicationContext = applicationContext;
        }
    }

    //获取applicationContext
    public static ApplicationContext getApplicationContext() {
        return applicationContext;
    }

    //通过name获取 Bean.
    public static Object getBean(String name){
        return getApplicationContext().getBean(name);
    }

    //通过class获取Bean.
    public static <T> T getBean(Class<T> clazz){
        return getApplicationContext().getBean(clazz);
    }

    //通过name,以及Clazz返回指定的Bean
    public static <T> T getBean(String name,Class<T> clazz){
        return getApplicationContext().getBean(name, clazz);
    }

}

我的job listener 源码:

package com.iflytek.quartz.listener;

import org.apache.log4j.Logger;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.quartz.JobListener;
import org.springframework.stereotype.Component;

import com.iflytek.quartz.service.QaTaskService;
import com.iflytek.quartz.util.SpringUtil;

/**
 * job 监听器
 * @author zhangh
 * @date 2018年5月25日下午2:06:46
 */
@Component
public class MyJobListener implements JobListener {
    private static Logger log = Logger.getLogger(MyJobListener.class);

    /**
     * 获取该JobListener的名称
     */
    @Override
    public String getName() {
        return getClass().getSimpleName();
    }

    /**
     * Scheduler在JobDetail将要被执行时调用这个方法
     */
    @Override
    public void jobToBeExecuted(JobExecutionContext context) {
        //log.info(context.getJobDetail().getKey().getName()+"任务准备执行");
    }

    /**
     * Scheduler在JobDetail即将被执行,但又被TriggerListerner否决时会调用该方法
     */
    @Override
    public void jobExecutionVetoed(JobExecutionContext context) {
        //log.info(context.getJobDetail().getKey().getName()+"任务准备执行时被触发器"+context.getTrigger().getKey().getName()+"否决了");
    }

    /**
     * Scheduler在JobDetail被执行之后调用这个方法
     * 主要是回写数据
     */
    @Override
    public void jobWasExecuted(JobExecutionContext context, JobExecutionException jobException) {
        log.info(context.getJobDetail().getKey().getName()+"任务执行完毕");
        QaTaskService qaTaskService = **SpringUtil.getBean(QaTaskService.class);**
        String jobtype = context.getJobDetail().getJobDataMap().get("jobType").toString();
        String jobID = context.getJobDetail().getJobDataMap().getString("id");
        if("1".equals(jobtype)){
            qaTaskService.updateStatus(jobID, "1");

        }else if ("2".equals(jobtype)){
            qaTaskService.updateStatus(jobID, "5");
        }

    }
}

猜你喜欢

转载自blog.csdn.net/forever_insist/article/details/80532874