严重: Error configuring application listener of class ibatis.apache.org.util.ApplicationListener
javax.naming.NamingException: Cannot create resource instance
at org.apache.naming.factory.ResourceEnvFactory.getObjectInstance(ResourceEnvFactory.java:115)
at javax.naming.spi.NamingManager.getObjectInstance(NamingManager.java:304)
at org.apache.naming.NamingContext.lookup(NamingContext.java:842)
at org.apache.naming.NamingContext.lookup(NamingContext.java:153)
at org.apache.naming.NamingContext.lookup(NamingContext.java:830)
at org.apache.naming.NamingContext.lookup(NamingContext.java:167)
at org.apache.catalina.core.DefaultInstanceManager.lookupFieldResource(DefaultInstanceManager.java:559)
at org.apache.catalina.core.DefaultInstanceManager.processAnnotations(DefaultInstanceManager.java:449)
at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:135)
at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:116)
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4919)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5517)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:652)
at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1263)
at org.apache.catalina.startup.HostConfig$DeployDirectory.run(HostConfig.java:1948)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:439)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)
at java.lang.Thread.run(Thread.java:662)
public class ApplicationListener implements ServletContextListener {
@Resource
private NoteTableDAO noteTableDAO;
@Resource
private NoteOperDAO noteOperDAO;
@Override
public void contextDestroyed(ServletContextEvent arg0) {
// TODO Auto-generated method stub
this.noteTableDAO = null;
this.noteOperDAO = null;
}
@Override
public void contextInitialized(ServletContextEvent servletcontextevent) {
// TODO Auto-generated method stub
//获取ServletContext对象
ServletContext servletContext = servletcontextevent.getServletContext();
//服务器启动的时候加载日志需要的信息
noteMap(servletContext);
}
private void noteMap(ServletContext servletContext) {
// TODO Auto-generated method stub
//获取日志表的对应数据
Map<String, String> noteTableMap = noteTableDAO.queryAllForMap();
//获取日志操作的对应数据
Map<String, String> noteOperMap = noteOperDAO.queryAllForMap();
//将查询到的结果存放至作用域
servletContext.setAttribute("noteTableMap", noteTableMap);
servletContext.setAttribute("noteOperMap", noteOperMap);
}
}
自己解决的:理由是,filter listener servlet 无法由spring 管理,因此用注解获取不到相应对象,必须通过getBean 的方式来获取。
值得一提的是,通过注解过的类也可以通过getBean("")方式获取到,而不必再进行相关配置。
解决方案:
public class ApplicationListener implements ServletContextListener {
//获取spring注入的bean对象
private WebApplicationContext springContext;
private NoteTableDAO noteTableDAO;
private NoteOperDAO noteOperDAO;
@Override
public void contextDestroyed(ServletContextEvent arg0) {
// TODO Auto-generated method stub
this.springContext = null;
this.noteTableDAO = null;
this.noteOperDAO = null;
}
@Override
public void contextInitialized(ServletContextEvent servletcontextevent) {
// TODO Auto-generated method stub
//获取ServletContext对象
ServletContext servletContext = servletcontextevent.getServletContext();
//服务器启动的时候加载日志需要的信息
noteMap(servletContext);
}
private void noteMap(ServletContext servletContext) {
// TODO Auto-generated method stub
springContext = WebApplicationContextUtils.getWebApplicationContext(servletContext);
if (springContext != null) {
noteOperDAO = (NoteOperDAO) springContext.getBean("noteOperDAO");
noteTableDAO = (NoteTableDAO) springContext.getBean("noteTableDAO");
//获取日志表的对应数据
Map<String, String> noteTableMap = noteTableDAO.queryAllForMap();
//获取日志操作的对应数据
Map<String, String> noteOperMap = noteOperDAO.queryAllForMap();
//将查询到的结果存放至作用域
servletContext.setAttribute("noteTableMap", noteTableMap);
servletContext.setAttribute("noteOperMap", noteOperMap);
}
}
public NoteTableDAO getNoteTableDAO() {
return noteTableDAO;
}
public void setNoteTableDAO(NoteTableDAO noteTableDAO) {
this.noteTableDAO = noteTableDAO;
}
public NoteOperDAO getNoteOperDAO() {
return noteOperDAO;
}
public void setNoteOperDAO(NoteOperDAO noteOperDAO) {
this.noteOperDAO = noteOperDAO;
}
@Resource 是byName jdk自带的注入 如果有多个或者没有名字,会抛出异常。 @Autowired是byType 可以用@Autowired试试 Spring的注入
Autowired能完成的 Resource都能完成。况且Listener是属于JavaEE范畴,怎么可能用Autowired?所以这个结论肯定是不成立的。
at org.apache.catalina.core.DefaultInstanceManager.lookupFieldResource(DefaultInstanceManager.java:559)
at org.apache.catalina.core.DefaultInstanceManager.processAnnotations(DefaultInstanceManager.java:449)
at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:135)
at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:116)
你这里是找到多个name重名的,