Mat*_*W90 5 java spring-aop spring-boot
我的目的是在服务中获取消息方法之前运行方面。我不想使用 xml 配置,所以我添加(希望)必要的注释。但是,当我运行我的应用程序时,aspect 不起作用,什么也没有发生。你能解释一下为什么吗?
服务
public interface Service {
void getMessage();
}
Run Code Online (Sandbox Code Playgroud)
服务实现
import org.springframework.stereotype.Component;
@Service
public class ServiceImpl implements Service {
public void getMessage() {
System.out.println("Hello world");
}
}
Run Code Online (Sandbox Code Playgroud)
方面
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
@Aspect
public class LoggingAspect {
@Before("execution(* com.example.aop.Service.getMessage())")
public void logBefore(JoinPoint joinPoint) {
System.out.println("AOP is working!!!");
}
}
Run Code Online (Sandbox Code Playgroud)
跑
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
@SpringBootApplication
@EnableAspectJAutoProxy(proxyTargetClass=true)
@ComponentScan("com.example")
public class AopApplication {
public static void main(String[] args) {
final ConfigurableApplicationContext run = SpringApplication.run(AopApplication.class, args);
final Service bean = run.getBean(ServiceImpl.class);
bean.getMessage();
}
}
Run Code Online (Sandbox Code Playgroud)
仅输出Hello world
| 归档时间: |
|
| 查看次数: |
1402 次 |
| 最近记录: |