*1.代码实现
①项目结构
②Controller
@RestController
public class AopTest {
@GetMapping("/hello")
public String helloaop(@RequestParam("name") String name){
return "helloaop" + name;
}
}
③AopController
@Aspect
@Component("com.dr.aoptest.aop")
public class MyAdvice {
private Logger logger = LoggerFactory.getLogger(MyAdvice.class);
//定义切面
@Pointcut(value = "execution( * com.dr.aoptest.aop.Controller.*.*(..))")
public void mypointcut(){
}
//环绕通知
@Around("mypointcut()")
public Object myLogger(ProceedingJoinPoint pjp) throws Throwable{
String className = pjp.getTarget().getClass().toString();
String methodName = pjp.getSignature().getName();
Object[] array = pjp.getArgs();
ObjectMapper mapper = new ObjectMapper();
logger.info("aop之前: " + className + ":" + methodName + "其中参数为: " + mapper.writeValueAsString(array));
Object obj = pjp.proceed();
logger.info("aop之后: " + className + ":" + methodName + "其中返回值为: " + mapper.writeValueAsString(obj));
return obj;
}
}
2.运行结果
3.相关理论
①首先明确以下几个概念(大白话)
AOP:
将程序中的交叉业务逻辑(⽐如安全,⽇志,事务等),封装成⼀个切⾯,然后注⼊到⽬标对象(具体业务逻辑)中去。AOP可以对某个对象或某些对象的功能进⾏增强,⽐如对象中的⽅法进⾏增强,可以在执⾏某个⽅法之前额外的做⼀些事情,在某个⽅法执⾏之后额外的做⼀些事情
通知类:
通知类:
管理增强方法功能的类
通知:
具体的方法
切面:
暂时不太懂,感觉没啥意义
切入点:
暂时不太懂,感觉没啥意义+1
连接点:
增强的位置
还有其他几种通知方式
4.解释
①几种通知方式