spring切面,在方法的执行前后切入代码,切入事物service层,或做一些日志操作。
AOP切面主要是切方法,我们一般搞一些日志分析和事务操作,要用到切面,类似拦截器;
@Aspect注解是切面注解类
@Pointcut切点定义
@Before是方法执行前调用
@After是方法执行后调用
@AfterReturning方法执行返回值调用
Service层本身就可以切入事务,所以我们这类搞个常用的 切controller层方法
每个执行controller层的方法 都记录下请求Url,访问者IP 执行类方法参数等信息;
@Pointcut定义切点,对controller任意类的任意方法进行切入,第一个*任意返回值 *.*任意类的任意方法
@Before("log()") 执行前调用 log()加入切点,通过切点joinPoint获得信息
@AfterReturning 方法的返回值 returning="result"指定返回参数和下面匹配
切面,切入点是这个controller 。注解@Pointcut 定义切入点,就是作用在哪个业务方法。execution(public * * com.java.controller.*.*(..)) 是一个表达式&#