zoukankan      html  css  js  c++  java
  • spring 初始化之后执行的方法

    Spring初始化完成后直接执行一个方法,初始化数据(解决方法并执行两次)

         在做WEB项目时,经常在项目第一次启动时利用WEB容器的监听、Servlet加载初始化等切入点为数据库准备数据,这些初始化数据 是系统开始运行前必须的数据,例如权限组、系统选项、默认管理员等等。但是项目若不是WEB工程,或者说还没用到WEB层(例如单元测试),这时应如何方 便地初始化数据呢?

        借助Spring容器是个很好的解决方案。Spring框架提供了事件机制,而事件机制必须实现ApplicationListener监听器,因此我们 只要编写一个实现类实现该接口的onApplicationEvent方法,在方法体中检测数据库的初始化数据是否存在并选择初始化之。

    第一步:定义一个类InitData实现ApplicationListener

    import java.util.HashMap;
    import java.util.Map;
    
    import org.apache.commons.logging.Log;
    import org.apache.commons.logging.LogFactory;
    import org.springframework.context.ApplicationEvent;
    import org.springframework.context.ApplicationListener;
    import org.springframework.stereotype.Controller;
    
    import com.ebay.cloud.cms.typsafe.metadata.model.MetaClass;
    import com.ebay.tools.cms.exception.UtilityException;
    import com.ebay.tools.cms.util.CommonInterfaceUtility;
    import com.ebay.tools.cms.util.ExceptionUtils;
    import com.ebay.tools.cms.util.LoggerUtil;
    
    /**
     * @author Josh Wang(Sheng)
     * @email swang6@email.com
     * 
     * This class used to initialize data / load data ON the application started 
     */
    @Controller
    public class InitData implements ApplicationListener<ApplicationEvent> {
        
        private Log logger = LogFactory.getLog(InitData.class);
        
        private static boolean isStart = false;
    
        private static Map<String, MetaClass> cmsMetas = new HashMap<String, MetaClass>();
    
        public void onApplicationEvent(ApplicationEvent event) {
            if (!isStart) {
                isStart = true;
                LoggerUtil.info(logger, "Start to load CMS Meta data");
                
                try {
                    cmsMetas = CommonInterfaceUtility.getMetaClass();
                } catch (UtilityException e) {
                    LoggerUtil.error(logger, "Load Meta Class failed" + ExceptionUtils.getStackTraceMsg(e));
                }
                
                LoggerUtil.info(logger,"End to load CMS Meta data");
                
                LoggerUtil.info(logger,"Start to load Other data");
                
                LoggerUtil.info(logger,"End to load Other data");
            }
            
        }

     第二步:解决onApplicationEvent(方法被执行两次以上的问题:

    原因:

          在web 项目中(spring mvc),系统会存在两个容器,一个是root application context ,另一个就是我们自己的 projectName-servlet  context(作为root application context的子容器)。 这种情况下,就会造成onApplicationEvent方法被执行两次。

    解决方法:

          如代码所示,只需要使用一个类变量isStart即可。

    需要注意的是,一定要加Annotation @Controller,这样才表示是一个Spring的Bean(否则在相关Spring的xml中配置),才能被Spring容器处理。

    第三步,写一个Spring JunitTest,注意相关的Annotation

    需要注意的就是在类上面加入如下两个Annotation即可:

    @ContextConfiguration(locations = "file:../validator-web/src/main/webapp/WEB-INF/cms-validator-servlet.xml")

    @RunWith(SpringJUnit4ClassRunner.class)

    @ContextConfiguration用于加载spring的核心配置文件,因为这个操作是一个公共的操作,所以我们常常可以写在一个BaseTest中。

    @ContextConfiguration(locations = "file:../validator-web/src/main/webapp/WEB-INF/cms-validator-servlet.xml")
    public class BaseTest {
    
    	/**
    	 * Set up the environment
    	 * @throws Exception
    	 */
    	@BeforeClass
    	public static void setUp() throws Exception {
                   
    	}
    	
    	public static void print(String message) {
    		System.out.println(message);
    	}
    
    	public static void printHighlight(String message) {
    		System.err.println(message);
    	}
    
    }

    然后只需要在你的测试类上用这个Annotation:@RunWith(SpringJUnit4ClassRunner.class)

    @RunWith(SpringJUnit4ClassRunner.class)
    public class TestCacheUtil extends BaseTest {
    
        @Test
        public void getCMSMetaAttributeType() throws UtilityException {
    
        }
    }
  • 相关阅读:
    AudioStreamer电话打进时崩溃
    ios中NSLog输出格式大全
    IOS Framework制作(一)
    UIButton上的文字添加阴影
    Tim Cook向员工发邮件,祝贺大家实现创纪录的季度
    ios 通讯录“写”操作大全
    AVAudioSession的Category
    IOS播放优酷视频
    iOS 设备的网页调试工具Firebug
    iOS中retain和copy的区别
  • 原文地址:https://www.cnblogs.com/wxd0108/p/4867926.html
Copyright © 2011-2022 走看看