javax.naming.NamingException: Cannot create resource instance報錯修改


//下面內容為網上獲取

avax.naming.NamingException: Cannot create resource instance 
at org.apache.naming.factory.ResourceEnvFactory.getObjectInstance(ResourceEnvFactory.java:115) 
at javax.naming.spi.NamingManager.getObjectInstance(NamingManager.java:321) 
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:582) 
at org.apache.catalina.core.DefaultInstanceManager.processAnnotations(DefaultInstanceManager.java:472) 
at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:159) 
at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:140) 
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4888) 
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5467) 
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 
at org.apache.catalina.core.ContainerBaseStartChild.call(ContainerBase.java:1559)atorg.apache.catalina.core.ContainerBaseStartChild.call(ContainerBase.java:1559)atorg.apache.catalina.core.ContainerBaseStartChild.call(ContainerBase.java:1549) 
at java.util.concurrent.FutureTask.run(FutureTask.java:262) 
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 
at java.lang.Thread.run(Thread.java:744) 
“` 
##原因:

package com.vrv.cems.listeners; 
import javax.annotation.Resource; 
import javax.servlet.http.HttpSession; 
import javax.servlet.http.HttpSessionEvent; 
import javax.servlet.http.HttpSessionListener; 
import org.springframework.context.ApplicationContext; 
import org.springframework.stereotype.Component; 
import org.springframework.web.context.WebApplicationContext;

import com.sys.common.util.DateUtils; 
import com.sys.common.util.UUIDUtils; 
import com.vrv.cems.log.domain.ManagerLoginLog; 
import com.vrv.cems.log.service.ManagerLoginLogService; 
import com.vrv.cems.mgr.auth.http.ManagerSessionUtils; 
import com.vrv.cems.mgr.auth.session.ManagerSession; 
import com.vrv.cems.mgr.domain.Manager; 
import com.vrv.cems.mgr.service.ManagerService; 
@Component 
public class LoginSessionListener implements HttpSessionListener { 
//登出 
private final int EXIT = 2; 
//非正常退出 
private final int ABNORMALEXIT = 3; 
private ManagerService managerService; 
public ManagerService getManagerService() { 
return managerService; 

public void setManagerService(ManagerService managerService) { 
this.managerService = managerService; 

@Override 
public void sessionCreated(HttpSessionEvent se) { 
// TODO Auto-generated method stub

}
@Override
public void sessionDestroyed(HttpSessionEvent se) {
    // TODO Auto-generated method stub
    HttpSession session = se.getSession();
     ManagerSession managerSession = ManagerSessionUtils.getManagerSession(session);
     if(managerSession == null){
         //正常退出
     }else{
         //非正常退出
         ApplicationContext context = (ApplicationContext)se.getSession().getServletContext().getAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE);
         ManagerLoginLogService managerLoginLogService = context.getBean("managerLoginLogService",ManagerLoginLogService.class);
         /*ManagerService managerService=context.getBean("managerService",ManagerService.class);*/
         String uuid = UUIDUtils.get32UUID();
         Manager manager= managerService.queryByAccount(managerSession.getAccount());
        /* Manager manager= managerService.queryByAccount(managerSession.getAccount());*/
         managerLoginLogService.save(new ManagerLoginLog(uuid,managerSession.getNiceName(),manager,EXIT,ABNORMALEXIT,DateUtils.getCurrentTimestamp(),managerSession.getLoginIp()));

     }
}

 

1:沒有在Spring Scan掃描器中加入該類的包名,就是用注解,相從Spring容器中獲取service實例(@Resource注解想從Spring容器中注入實例,不好意思,人家Spring更本沒給你分配資源)

2:在Spring中掃描器加入該包,沒有在該類體上加(@Component)注解,就想用@Resource取出service實例,不好意思人家Spring根本沒找到說的這個類

3:如果你懶得配這些配置文件,我敢說你是一名出色的程序員-懶,解決方法也是有的,像類中這樣

ApplicationContext context = (ApplicationContext)se.getSession().getServletContext().getAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE); 
ManagerLoginLogService managerLoginLogService = context.getBean(“managerLoginLogService”,ManagerLoginLogService.class);

什么掃描什么裝配,都是浮雲,我們自己去上下文對象中 ApplicationContext context 去取擁有資源的Spring容器中取就行了 ,取出service了,這個問題也能解決

 

 

//下面內容為本人修改問題原因:

在Tomcat配置文件service.xml中

<Resource name="jdbc/mqService" 

上述name名稱重復,導致以上問題的出現,注釋掉不用的,或者刪除即可


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM