Выкинь исключение после добавления конфига aop
Сначала у меня весеннее приложение отлично работает:
но когда добавить aop config в aop.xml следующим образом, возникает исключение lang.
это AOP.java:
import org.springframework.beans.factory.BeanFactory;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.animal.Cat;
public class AOP {
public static void main(String args[]){
System.out.println("1");
BeanFactory factory = new ClassPathXmlApplicationContext("aop.xml");
Cat c1 =(Cat)factory.getBean("cat1");
System.out.println("2");
c1.mark();
}
}
это Cat.java:
package com.animal;
public class Cat {
public void mark(){
System.out.println("cat is mark");
}
}
это Rat.java:
package com.animal;
public class Rat {
public void sleep(){
System.out.println("rat is sleep");
}
public void run(){
System.out.println("rat running");
}
}
это XML-файл:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
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="cat1" class="com.animal.Cat">
</bean>
<bean id="rat1" class="com.animal.Rat">
</bean>
<aop:config>
<aop:pointcut id="cat_mark" expression="execution(public void com.animal.Cat.mark())" />
<aop:aspect ref="rat1">
<aop:before method="sleep" pointcut-ref="cat_mark" />
<aop:after method="run" pointcut-ref="cat_mark" />
</aop:aspect>
</aop:config>
Как вы можете видеть, это очень простое приложение, я просто хочу использовать Spring AOP, чтобы заставить крысу выполнить какое-либо действие, прежде чем кошка перейдет к метке.
У меня есть файл конфигурации XML, который копируется из какого-то учебника, но я не могу найти, что с ним не так.
да я скучаю aspectjweaver.jar
который org.springframework.context
требуется. Это решение:
1 ответ
Вы отредактировали свой вопрос, поэтому я редактирую свой ответ, потому что теперь я могу воспроизвести вашу проблему.
На самом деле ваш первоначальный pointcut был правильным. Забудьте, что я сказал о том, что это неправильно, я неправильно проанализировал это, когда впервые увидел это. Просто измените его обратно на использование только одного *
, пожалуйста:
execution(* com.animal.Cat.mark(..))
Теперь я думаю, что ваша проблема гораздо проще, если судить по колл-стеку, который вы опубликовали ранее, но обрезал его, чтобы заменить скриншот неполного стека. Но я нашел это в истории вашего вопроса, глядя на старую версию:
...
Caused by: java.lang.ClassNotFoundException: org.aspectj.weaver.reflect.ReflectionWorld$ReflectionWorldException
Я полагаю, вы просто забыли поставить aspectjweaver.jar
(или версионное имя как aspectjweaver-1.8.13
) на пути к классам при запуске приложения. Сделайте это, и это должно уйти. Если я это сделаю, ваше приложение напечатает:
1
Apr 20, 2018 6:04:34 PM org.springframework.context.support.ClassPathXmlApplicationContext prepareRefresh
INFORMATION: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@18769467: startup date [Fri Apr 20 18:04:34 ICT 2018]; root of context hierarchy
Apr 20, 2018 6:04:35 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFORMATION: Loading XML bean definitions from class path resource [aop.xml]
2
rat is sleep
cat is mark
rat running