nested exception is java.lang.IllegalArgumentException: warning no match for this type name: res [Xlint:invalidAbsoluteTypeName]
注:内有单词(sping)写错,请忽略,不影响程序运行
运行时报错:
Exception in thread "main" org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'mhl' defined in class path resource [myjava/wicherspingaop-aop.xml]: BeanPostProcessor before instantiation of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.aop.aspectj.AspectJPointcutAdvisor#2': Bean instantiation via constructor failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.springframework.aop.aspectj.AspectJPointcutAdvisor]:
Constructor threw exception; nested exception is java.lang.IllegalArgumentException: warning no match for this type name: res [Xlint:invalidAbsoluteTypeName]
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:479)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:312)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:308)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:761)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:867)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:543)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:83)
at myjava.Main.main(Main.java:9)
代码如下:
Main.java
package myjava; import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; public class Main {
public static void main(String[] args){
//获取IOC容器
ApplicationContext context = new ClassPathXmlApplicationContext("myjava/wicherspingaop-aop.xml");
Itest_1 mhl = context.getBean("mhl", Itest_1.class) ;
// mhl.sayHello();
mhl.saveToDB("zzzzz") ;
}
}
Itest_1.java
package myjava;
public interface Itest_1 {
void sayHello() ;
String saveToDB(String mData) ;
}
test_1.java
package myjava;
public class test_1 implements Itest_1 {
private String name ;
public test_1(){
}
public test_1(String name){
this.name = name ;
}
public void setName(String name){
this.name = name ;
}
public void sayHello(){
System.out.println("sayHello " + name);
}
public String saveToDB(String mData){
System.out.println("SaveToDB: " + mData);
return "tt" ;
}
}
mylog.java
package myjava;
import org.aspectj.lang.ProceedingJoinPoint;
public class mylog {
// 1 - error; 2 - warn ; 3 - debug; 4 - info ;
private int loglvl = 3 ;
public void info(String mlog){
if (loglvl == 4){
System.out.println("Info:" + mlog);
}
}
public void debug(String mlog){
if (loglvl >= 3) {
System.out.println("debug:" + mlog);
}
}
public void warn(String mlog){
if (loglvl >= 2) {
System.out.println("warn:" + mlog);
}
}
public void error(String mlog){
if (loglvl >= 1) {
System.out.println("error:" + mlog);
}
}
//前置通知
public void beforeAdvice(String messages){
System.out.println("前置通知, param:" + messages);
}
//后置返回通知
public void afterReturn(String res){
System.out.println("后置返回通知,返回值:" + res);
//System.out.println("==============================");
}
//后置异常通知
public void afterThrowing(Exception exception){
System.out.println("后置异常通知:" + exception);
}
//后置最终通知
public void afterFinally(String messages){
System.out.println("后置最终通知:" + messages);
}
//环绕通知
public String aroundAdvice(ProceedingJoinPoint joinPoint, String messages) throws Throwable{
try {
System.out.println("环绕通知,接入点:" + joinPoint + ",原param:" + messages);
System.out.println("放行目标方法并改变参数,将执行结果返回");
String res = (String) joinPoint.proceed(new Object[] {"param has been replaced "});
System.out.println("环绕通知改变了返回结果");
res = res.concat("& res has been changed");
System.out.println("返回结果为:"+res);
return res;
}catch (Exception e){
e.printStackTrace();
}
return null;
}
}
wicherspingaop-aop.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="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"
> <bean id = "mhl" class="myjava.test_1">
<property name="name" value="Wicher"></property>
</bean> <bean id = "log" class="myjava.mylog"></bean> <!--顶层的AOP配置元素,大多数的<aop:*>包含在<aop:config>元素内-->
<aop:config>
<!--定义外部切入点,该切入点可以被多个切面使用-->
<aop:pointcut id="pointcut_log" expression="execution(* myjava.test_1.* (..)) and args(messages)"/>
<!--定义切面-->
<aop:aspect ref="log">
<!--定义内部切入点,该切入点只能被当前切面使用-->
<!--<aop:pointcut id="pointcut_log_inner" expression="execution(* myjava.test_1.* (..)) and args(messages)"/>--> <!--前置通知-->
<aop:before method="beforeAdvice" arg-names="messages" pointcut-ref="pointcut_log"/>
<!--后置通知 不管该方法是否执行成功-->
<aop:after method="afterFinally" arg-names="messages" pointcut="execution(* myjava.test_1.* (..)) and args(messages)"/>
<!--后置返回通知 在方法成功执行后调用通知-->
<!--<aop:after-returning method="afterReturn" arg-names="res" returning="res" pointcut="execution(* myjava.test_1.* (..))"/>-->
<aop:after-returning method="afterReturn" arg-names="res" returning="res" pointcut="execution(* myjava.test_1.* (..)) and args(res)"/>
<!--后置异常通知 在方法抛出异常后调用通知-->
<aop:after-throwing method="afterThrowing" arg-names="exception" pointcut="execution(* myjava.test_1.* (..)) and args(exception)"/>
<!--环绕通知-->
<aop:around method="aroundAdvice" arg-names="joinPoint,messages" pointcut="execution(* myjava.test_1.* (..)) and args(messages)"/>
</aop:aspect>
</aop:config>
</beans>
工程路径

从网上down的demo能正常运行,自己先排错,把xml中环绕通知隐藏,运行正常,依次把前置通知(before),后置通知(after)取消隐藏,运行正常,再将after-returning取消隐藏时错,仔细与demo对比,发现在aop:after-returning的属性pointcut中是没有and args(res)的,去掉后运行正常, 因为对aop配置文件还不太熟,原因还不知道,后续确定原因后再记录。
全部lib文件如下(com.springsource.org.aspectj.weaver-1.6.4.RELEASE.jar是手工下载的,其他都是在建立spring时勾选的download自动下载):

后置通知
nested exception is java.lang.IllegalArgumentException: warning no match for this type name: res [Xlint:invalidAbsoluteTypeName]的更多相关文章
- Spring AOP 开发中遇到问题:Caused by: java.lang.IllegalArgumentException: warning no match for this type name: com.xxx.collector.service.impl.XxxServiceImpl [Xlint:invalidAbsoluteTypeName]
在网上找了很多,都不是我想要的,后来发现是我在springaop注解的时候 写错了类名导致的这个问题 @Pointcut("execution(* com.xxx.collector.ser ...
- nested exception is java.lang.IllegalArgumentException: Pointcut is not well-formed
在用AOP 的时候出现了如下的错误, 警告: Exception encountered during context initialization - cancelling refresh atte ...
- 异常:Injection of autowired dependencies failed; nested exception is java.lang.IllegalArgumentException
这个异常是出现在注入配置文件中配置好的属性时报错的: Injection of autowired dependencies failed; nested exception is java.lang ...
- IDEA报错: Injection of autowired dependencies failed; nested exception is java.lang.IllegalArgumentException: Could not resolve placeholder 'spring.datasource.url' in value "${spring.datasource.url}"
运行审核流模块: 在ActivitiServiceApplication模块日志报错: Error starting ApplicationContext. To display the auto-c ...
- org.hibernate.QueryException: JPA-style positional param was not an integral ordinal; nested exception is java.lang.IllegalArgumentException: org.hibernate.QueryException: JPA-style positional param w
org.hibernate.QueryException: JPA-style positional param was not an integral ordinal; nested excepti ...
- Initialization of bean failed; nested exception is java.lang.IllegalArgumentException: Pointcut is not well-formed: expecting 'name pattern' at character position 36
例: <aop:config> <aop:pointcut expression="execution(* com.zsn.Service.Impl.*.*(..))&qu ...
- MyBatis与Spring MVC结合时,使用DAO注入出现:Invocation of init method failed; nested exception is java.lang.IllegalArgumentException: Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required
错误源自使用了这个例子:http://www.yihaomen.com/article/java/336.htm,如果运行时会出现如下错误: Invocation of init method fai ...
- HTTP Status 500 - Request processing failed; nested exception is java.lang.IllegalArgumentException: Control character in cookie value or attribute.
HTTP Status 500 - Request processing failed; nested exception is java.lang.IllegalArgumentException: ...
- org.springframework.dao.InvalidDataAccessApiUsageException: The given id must not be null!; nested exception is java.lang.IllegalArgumentException: The given id must not be null
通过这个简单的案例,手把手教给你分析异常信息(适合初学者看) org.springframework.dao.InvalidDataAccessApiUsageException: The given ...
随机推荐
- 请求http协议分析- (mysql-thinkphp) (5)
http协议 https://tools.ietf.org/pdf/rfc7231.pdf https://www.w3.org/Protocols/ ======================== ...
- 数据库建表并返回给前端 - (mysql-thinkphp) (3)
1.先建一个表,你可以用mysql代码建,也可以用thinkphp建,也可以视图建,我用不到太复杂的,就用视图建了. 2.配置id为自增,唯一的值,不可重复.主键.要输入中文的选择utf8_gener ...
- Activity的生命周期及协同作用
生命周期 onCreate:创建Activity的实例对象的方法 onStart:启动当前的activity实例的方法 onResume:如果该方法执行,页面的实例和用户即可以交互 onPause:如 ...
- mysql 命令行导入导出.sql文件
window下 1.导出整个数据库mysqldump -u 用户名 -p 数据库名 > 导出的文件名mysqldump -u dbuser -p dbname > dbname.sql 2 ...
- GoJS API学习
var node = {}; node["key"] = "节点Key"; node["loc"] = "0 0";// ...
- Spark 资料整理
http://jerryshao.me/architecture/2013/10/08/spark-storage-module-analysis/ http://blog.csdn.net/aliv ...
- makecert 制作数字证书 给DLL加一个数字签名
声明:文章整理自互联网 我仅需要给dll添加(替换)一个签名,所以我只看了第一步和第三步,其余的部分我没有测试,不能保证内容的是否正确. 看了很多关于DLL加签名的教程 大多是错误的 完全无法正常走下 ...
- maven package跳过测试
mvn clean package -DskipTests 或者 mvn clean package -Dmaven.test.skip=true 区别 -DskipTests,不执行测试用例,但编译 ...
- use matplotlib to drew a table
$sudo apt-get install python3-matplotlib gyf@gyf-VirtualBox:~$ python3Python 3.6.9 (default, Nov 7 ...
- SpringBoot+Jpa测试自增时报错Springboot-jpa Table 'sell.hibernate_sequence' doesn't exist
解决办法: @GeneratedValue(strategy = GenerationType.IDENTITY) 如图所示: