java.lang.IllegalArgumentException:警告此类型名称不匹配:UserDaoImpl [Xlint:invalidAbsoluteTypeName]

时间:2011-06-11 12:33:42

标签: java spring aop

我正在开发一个基于Spring 3.0.2的项目。从过去三天开始显示以下错误。

  

java.lang.IllegalArgumentException:警告此类型名称不匹配:UserDaoImpl [Xlint:invalidAbsoluteTypeName]

如何解决此错误?

我的applicationContext文件是:

<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
        xmlns:p="http://www.springframework.org/schema/p"
        xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="
            http://www.springframework.org/schema/context
            http://www.springframework.org/schema/context/spring-context.xsd
            http://www.springframework.org/schema/beans
            http://www.springframework.org/schema/beans/spring-beans.xsd
            http://www.springframework.org/schema/aop
            http://www.springframework.org/schema/aop/spring-aop.xsd">

        <aop:aspectj-autoproxy/>
        <context:component-scan base-package="web"/>
<!--        <import resource="appicationContext.xml"/>        -->

    <bean id="viewResolver"
          class="org.springframework.web.servlet.view.InternalResourceViewResolver"
          p:prefix="jsp/" p:suffix=".jsp" />  

    <bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" />

    <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />


        <bean id="sessionFactory" class="hibernatefiles.HibernateUtil" factory-method="getSessionFactory"/>           

        <bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
                <property name="sessionFactory" ref="sessionFactory"/>
        </bean>

        <bean id="userDaoImpl"  class="dao.UserDaoImpl"/>

        <bean id = "profiler" class = "Profiler.AspectProfiler" />

     <bean name="/userRegistration.htm" class="web.UserController" depends-on="userDaoImpl">
            <property name="userDaoImpl" ref="userDaoImp"/>       
     </bean>       
</beans>

堆栈跟踪是:

   org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userController' defined in file [D:\JAVA Stuffs\projects\NewSpringDemo\build\web\WEB-INF\classes\web\UserController.class]: Initialization of bean failed; nested exception is java.lang.IllegalArgumentException: warning no match for this type name: **UserDaoImpl [Xlint:invalidAbsoluteTypeName]**
        org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:527)
        org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
        org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:291)
        org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
        org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:288)
        org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:190)
        org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:563)
        org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:872)
        org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:423)
        org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:442)
        org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:458)
        org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.java:339)
        org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:306)
        org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:127)
        javax.servlet.GenericServlet.init(GenericServlet.java:160)
        org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:498)
        org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
        org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562)
        org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:394)
        org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:243)
        org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188)
        org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
        java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
        java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
        java.lang.Thread.run(Thread.java:662)
    root cause

    java.lang.IllegalArgumentException: warning no match for this type name: UserDaoImpl [Xlint:invalidAbsoluteTypeName]
        org.aspectj.weaver.tools.PointcutParser.parsePointcutExpression(PointcutParser.java:315)
        org.springframework.aop.aspectj.AspectJExpressionPointcut.buildPointcutExpression(AspectJExpressionPointcut.java:204)
        org.springframework.aop.aspectj.AspectJExpressionPointcut.checkReadyToMatch(AspectJExpressionPointcut.java:191)
        org.springframework.aop.aspectj.AspectJExpressionPointcut.getClassFilter(AspectJExpressionPointcut.java:172)
        org.springframework.aop.support.AopUtils.canApply(AopUtils.java:200)
        org.springframework.aop.support.AopUtils.canApply(AopUtils.java:254)
        org.springframework.aop.support.AopUtils.findAdvisorsThatCanApply(AopUtils.java:286)
        org.springframework.aop.framework.autoproxy.AbstractAdvisorAutoProxyCreator.findAdvisorsThatCanApply(AbstractAdvisorAutoProxyCreator.java:117)
        org.springframework.aop.framework.autoproxy.AbstractAdvisorAutoProxyCreator.findEligibleAdvisors(AbstractAdvisorAutoProxyCreator.java:87)
        org.springframework.aop.framework.autoproxy.AbstractAdvisorAutoProxyCreator.getAdvicesAndAdvisorsForBean(AbstractAdvisorAutoProxyCreator.java:68)
        org.springframework.aop.framework.autoproxy.AbstractAutoProxyCreator.wrapIfNecessary(AbstractAutoProxyCreator.java:359)
        org.springframework.aop.framework.autoproxy.AbstractAutoProxyCreator.postProcessAfterInitialization(AbstractAutoProxyCreator.java:322)
        org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsAfterInitialization(AbstractAutowireCapableBeanFactory.java:407)
        org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1418)
        org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
        org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
        org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:291)
        org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
        org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:288)
        org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:190)
        org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:563)
        org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:872)
        org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:423)
        org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:442)
        org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:458)
        org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.java:339)
        org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:306)
        org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:127)
        javax.servlet.GenericServlet.init(GenericServlet.java:160)
        org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:498)
        org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
        org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:562)
        org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:394)
        org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:243)
        org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:188)
        org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
        java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
        java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
        java.lang.Thread.run(Thread.java:662)
...

userDaoImpl在UserController类中自动装配,该类使用@Controller进行注释:

/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package web;

import dao.UserDaoImpl;
import domain.UsersTable;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.SessionAttributes;
import org.springframework.web.servlet.ModelAndView;

/**
 *
 * @author amit
 */

@Controller
@RequestMapping("/userRegistration.htm")
@SessionAttributes("user")
public class UserController {

    @Autowired
    private UserDaoImpl userDaoImpl;

    public UserDaoImpl getUserDaoImpl() {
        return userDaoImpl;
    }

    public void setUserDaoImpl(UserDaoImpl userDaoImpl) {
        this.userDaoImpl = userDaoImpl;
    }   

    @RequestMapping(method = RequestMethod.GET)
    public String showForm(ModelMap model) {
        System.out.println("Get request found. . . . *****************************");
        UsersTable user = new UsersTable();
        model.addAttribute("user", user);
        return "registrationForm";
    }

    @RequestMapping(method = RequestMethod.POST)
    public ModelAndView OnSubmit(@ModelAttribute("user") UsersTable user) {
        System.out.println("User Object is : "+user);
        userDaoImpl.saveUser(user);
        return new ModelAndView("userConfirm", "user", user);
    }
}

Aspect Profiler:

package Profiler;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;

@Aspect
public class AspectProfiler {
   @Pointcut("execution(* UserDaoImpl.mySave())")
            public void insertionProfiler(){ }

    @Around("insertionProfiler()")
            public void aroundInsertionProfiler(ProceedingJoinPoint pjp) throws Throwable{
            System.out.println("Before Insertion....");
            pjp.proceed();
            System.out.println("After saving the data I am back.");
    }

}

4 个答案:

答案 0 :(得分:4)

我不知道为什么今天我的RSS提要会出现这个旧问题,但仅仅是为了记录,正确的答案是在注释风格的AspectJ切入点中你需要使用完全限定的类名 < em>包括包名 ,即切入点应为

@Pointcut("execution(* dao.UserDaoImpl.mySave())")

这就是[Xlint:invalidAbsoluteTypeName]首先暗示的内容。

我想知道为什么在2011年没有其他人注意到这一点。

答案 1 :(得分:2)

是注释之间的空格。和

中的类名
<bean class="org.springframework.web.servlet.mvc.annotation. DefaultAnnotationHandlerMapping" />

<bean class="org.springframework.web.servlet.mvc.annotation. AnnotationMethodHandlerAdapter" />

这里只有一个复制粘贴错误,或者它们是否真的在你的xml中?如果是,请将其删除并重试。

答案 2 :(得分:1)

您的UserController已将 @Autowired 属性命名为UserDaoImpl。这是无效的,应该是userDaoImpl

答案 3 :(得分:0)

            

你丢了“l”,应该是“userDaoImpl”。