首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 企业软件 > 行业软件 >

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

2013-12-19 
Spring初始化完成后直接执行一个方法,初始化数据(解决方法并执行两次)import java.util.HashMapimport ja

Spring初始化完成后直接执行一个方法,初始化数据(解决方法并执行两次)
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 */@Controllerpublic 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 */@BeforeClasspublic 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 {    }}

?

?

?

热点排行