小蚂蚁 发表于 2021-12-31 14:07:09

Spring源码深度解析(第2版)- 解决无法运行AOP使用示例的错误(aspectj)

一、前言
按照书中示例运行会报错:找不到符号:类 JCacheCacheAspect、JtaAnnotationTransactionAspect、AnnotationTransactionAspect 、AnnotationCacheAspect 、AnnotationAsyncExecutionAspect 、AnnotationBeanConfigurerAspect 具体如下:
D:\workspace\spring-framework\spring-aspects\src\main\java\org\springframework\cache\aspectj\AspectJJCacheConfiguration.java
Error:(42, 16) java: 找不到符号
符号:   类 JCacheCacheAspect
位置: 类 org.springframework.cache.aspectj.AspectJJCacheConfiguration
Error:(43, 17) java: 找不到符号
符号:   类 JCacheCacheAspect
位置: 类 org.springframework.cache.aspectj.AspectJJCacheConfiguration
Error:(43, 49) java: 找不到符号
符号:   变量 JCacheCacheAspect
位置: 类 org.springframework.cache.aspectj.AspectJJCacheConfiguration
D:\workspace\spring-framework\spring-aspects\src\main\java\org\springframework\transaction\aspectj\AspectJJtaTransactionManagementConfiguration.java
Error:(43, 16) java: 找不到符号
符号:   类 JtaAnnotationTransactionAspect
位置: 类 org.springframework.transaction.aspectj.AspectJJtaTransactionManagementConfiguration
Error:(44, 17) java: 找不到符号
符号:   类 JtaAnnotationTransactionAspect
位置: 类 org.springframework.transaction.aspectj.AspectJJtaTransactionManagementConfiguration
Error:(44, 59) java: 找不到符号
符号:   变量 JtaAnnotationTransactionAspect
位置: 类 org.springframework.transaction.aspectj.AspectJJtaTransactionManagementConfiguration
D:\workspace\spring-framework\spring-aspects\src\main\java\org\springframework\transaction\aspectj\AspectJTransactionManagementConfiguration.java
Error:(43, 16) java: 找不到符号
符号:   类 AnnotationTransactionAspect
位置: 类 org.springframework.transaction.aspectj.AspectJTransactionManagementConfiguration
Error:(44, 17) java: 找不到符号
符号:   类 AnnotationTransactionAspect
位置: 类 org.springframework.transaction.aspectj.AspectJTransactionManagementConfiguration
Error:(44, 56) java: 找不到符号
符号:   变量 AnnotationTransactionAspect
位置: 类 org.springframework.transaction.aspectj.AspectJTransactionManagementConfiguration
D:\workspace\spring-framework\spring-aspects\src\main\java\org\springframework\cache\aspectj\AspectJCachingConfiguration.java
Error:(42, 16) java: 找不到符号
符号:   类 AnnotationCacheAspect
位置: 类 org.springframework.cache.aspectj.AspectJCachingConfiguration
Error:(43, 17) java: 找不到符号
符号:   类 AnnotationCacheAspect
位置: 类 org.springframework.cache.aspectj.AspectJCachingConfiguration
Error:(43, 53) java: 找不到符号
符号:   变量 AnnotationCacheAspect
位置: 类 org.springframework.cache.aspectj.AspectJCachingConfiguration
D:\workspace\spring-framework\spring-aspects\src\main\java\org\springframework\scheduling\aspectj\AspectJAsyncConfiguration.java
Error:(44, 16) java: 找不到符号
符号:   类 AnnotationAsyncExecutionAspect
位置: 类 org.springframework.scheduling.aspectj.AspectJAsyncConfiguration
Error:(45, 17) java: 找不到符号
符号:   类 AnnotationAsyncExecutionAspect
位置: 类 org.springframework.scheduling.aspectj.AspectJAsyncConfiguration
Error:(45, 62) java: 找不到符号
符号:   变量 AnnotationAsyncExecutionAspect
位置: 类 org.springframework.scheduling.aspectj.AspectJAsyncConfiguration
D:\workspace\spring-framework\spring-aspects\src\main\java\org\springframework\context\annotation\aspectj\SpringConfiguredConfiguration.java
Error:(19, 49) java: 找不到符号
符号:   类 AnnotationBeanConfigurerAspect
位置: 程序包 org.springframework.beans.factory.aspectj
Error:(47, 16) java: 找不到符号
符号:   类 AnnotationBeanConfigurerAspect
位置: 类 org.springframework.context.annotation.aspectj.SpringConfiguredConfiguration
Error:(48, 24) java: 找不到符号
符号:   变量 AnnotationBeanConfigurerAspect
位置: 类 org.springframework.context.annotation.aspectj.SpringConfiguredConfiguration

二、解决步骤

1.问题原因
通过百度查询到问题原因是spring源码的AOP使用了aspectj,而java不识别aspectj
百度百科:




2.下载AspectJ

​​​https://www.eclipse.org/aspectj/downloads.php​​​


3.安装
win10安装办法,在cmd窗口中执行

弹出

安装完 


4.添加facet属性


选择spring.spring-aop.main 

按照上述步骤添加spring.spring-aspects.main
最后的结果展示如图


5.更改编译器



三、运行AOP使用示例

1.gradle引入aop相关项目


2.源码
TestBean
public class TestBean {

private String testStr;

public String getTestStr() {
    return testStr;
}

public void setTestStr(String testStr) {
    this.testStr = testStr;
}

public void test() {
    System.out.println("test");
}
}

AspectJTest 
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;

@Aspect
public class AspectJTest {

@Pointcut("execution(* *.test(..))")
public void test() {

}

@Before("test()")
public void beforeTest() {
    System.out.println("beforeTest");
}

@After("test()")
public void afterTest() {
    System.out.println("afterTest");
}

public Object aroundTest(ProceedingJoinPoint p) {
    System.out.println("before1");
    Object o = null;
    try {
      o = p.proceed();
    } catch (Throwable e) {
      e.printStackTrace();
    }
    System.out.println("after1");
    return o;
}

}
AspectTestDoMain 
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class AspectTestDoMain {

public static void main(String[] args) {
    ApplicationContext bf = new ClassPathXmlApplicationContext("chapter07/aspectTest.xml");
    TestBean bean = (TestBean) bf.getBean("test");
    bean.test();

}

}
aspectTest.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-3.0.xsd
    http://www.springframework.org/schema/aop
    http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
    http://wwww.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<aop:aspectj-autoproxy/>
<bean id="test" class="com.asyf.chapter07.TestBean"/>
<bean class="com.asyf.chapter07.AspectJTest"/>
</beans>


3.测试

​​​​




https://blog.51cto.com/u_14998860/4866939
页: [1]
查看完整版本: Spring源码深度解析(第2版)- 解决无法运行AOP使用示例的错误(aspectj)