springboot笔记09——使用aop
什么是AOP?
aop(Aspect Oriented Programming)面向切面编程,是OOP(Object-Oriented Programing,面向对象编程)的补充和完善。OOP引入封装、继承和多态性等概念来建立一种对象层次结构,用以模拟公共行为的一个集合。但是在为分散的对象引入公共行为的时候,OOP显得无能为力。OOP擅长从上到下的关系,但是不适合从左到右的关系,例如日志、权限,这些功能的代码往往是水平地分布在对象层次中,而与所在的对象的核心功能关系不大。这些代码称为“横切”代码,在OOP中,这导致了大量的代码冗余,且不利于模块间代码的重用。
AOP则擅长于切面编程,将那些影响多个类的公共行为封装到一个模块中,供其他模块重用,便于减少重复代码,降低模块间的耦合度,提高系统的可操作性和可维护性。
一些关于aop的术语
- Aspect: 切面,包含一些Pointcut和Advice
- Pointcut:切入点,相当于一个条件,只有符合条件的方法才会走Advice
- advice:通知,只有符合Pointcut的方法会执行通知,advice分为before,around,after,AfterReturning,AfterThrowing
- advice通过以下几种通知来确定在什么时候调用advice
- @before:前置通知,方法执行之前调用advice
- @around:环绕通知,方法执行前后都会调用advice
- @after:后置通知,方法执行之后调用advice(无论方法执行是否发送异常,总是调用)
- @AfterReturning:后置通知,方法执行之后调用advice,可以获取返回值 (无论方法执行是否发送异常,总是调用)
- @AfterThrowing:后置通知,方法执行中发生异常后调用,可以获取异常信息(只有发生异常才会)
springboot使用aop
创建项目,引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
Aspect配置类
@Aspect
@Component
public class MyAspect {
/*
* 切入点
* */
@Pointcut("execution(public * com.jotal.springboot07aop.controller.*.*(..))")
public void execute() {
}
/*
* 前置通知
* */
@Before(value = "execute()")
public void Before(JoinPoint joinPoint) {
System.out.println("执行方法之前!");
}
/*
* 环绕通知
* */
@Around(value = "execute()")
public Object around(ProceedingJoinPoint proceedingJoinPoint){
System.out.println("环绕通知开始");
try {
System.out.println("执行方法:"+proceedingJoinPoint.getSignature().getName());
Object Object = proceedingJoinPoint.proceed();
System.out.println("环绕结束,方法返回:"+Object);
return Object;
} catch (Throwable e) {
System.out.println("执行方法异常:"+e.getClass().getName());
return null;
}
}
/*
* 后置通知
* */
@After(value = "execute()")
public void after(){
System.out.println("执行方法之后!");
}
/*
* 后置通知,带有返回值
* */
@AfterReturning(pointcut = "execute()",returning = "obj")
public void afterReturn(Object obj){
System.out.println("执行方法后获取返回值:" + obj);
}
/*
* 后置通知,异常时执行
* */
@AfterThrowing(throwing = "e",pointcut = "execute()")
public void doAfterThrowing(Exception e){
System.out.println("执行方法异常:" + e.getClass().getName());
}
}
@Aspect :标注切面类
@Component:注入spring ioc容器管理
@Pointcut("execution(public * com.jotal.springboot07aop.controller.*.*(..))"):声明切入点
"execution(public * com.jotal.springboot07aop.controller.*.*(..))":条件表达式, com.jotal.springboot07aop.controller包下的public声明的方法都会使用aop
@Before,@Around,@After,@AfterReturning,@AfterThrowing:通知类型
控制类
@RestController
public class testController {
@GetMapping("/useAop")
public String useAop(){
return "方法的返回";
}
@GetMapping("/doNotUseAop")
void doNotUseAop(){
System.out.println("doNotUseAop");
}
@GetMapping("/throw")
public void throwException(){
throw new RuntimeException();
}
}
测试
有通知
http://localhost:8080/doNotUseAop
无通知
抛出异常
springboot笔记09——使用aop的更多相关文章
- JAVA自学笔记09
JAVA自学笔记09 1.子类的方法会把父类的同名方法覆盖(重写) 2.final: 1)可修饰类.方法.变量 2)修饰类时:此时该类变为最终类,它将无法成为父类而被继承 3)修饰方法时:该方法将无法 ...
- 机器学习实战(Machine Learning in Action)学习笔记————09.利用PCA简化数据
机器学习实战(Machine Learning in Action)学习笔记————09.利用PCA简化数据 关键字:PCA.主成分分析.降维作者:米仓山下时间:2018-11-15机器学习实战(Ma ...
- 强化学习读书笔记 - 09 - on-policy预测的近似方法
强化学习读书笔记 - 09 - on-policy预测的近似方法 参照 Reinforcement Learning: An Introduction, Richard S. Sutton and A ...
- 【SpringBoot】SpingBoot整合AOP
https://blog.csdn.net/lmb55/article/details/82470388 [SpringBoot]SpingBoot整合AOPhttps://blog.csdn.net ...
- C++ GUI Qt4学习笔记09
C++ GUI Qt4学习笔记09 qtc++ 本章介绍Qt中的拖放 拖放是一个应用程序内或者多个应用程序之间传递信息的一种直观的现代操作方式.除了剪贴板提供支持外,通常它还提供数据移动和复制的功 ...
- SpringBoot应用中使用AOP记录接口访问日志
SpringBoot应用中使用AOP记录接口访问日志 本文主要讲述AOP在mall项目中的应用,通过在controller层建一个切面来实现接口访问的统一日志记录. AOP AOP为Aspect Or ...
- Java:并发笔记-09
Java:并发笔记-09 说明:这是看了 bilibili 上 黑马程序员 的课程 java并发编程 后做的笔记 7. 共享模型之工具-2 原理:AQS 原理 对于 AQS 的原理这部分内容,没很好的 ...
- Spring 源码学习笔记10——Spring AOP
Spring 源码学习笔记10--Spring AOP 参考书籍<Spring技术内幕>Spring AOP的实现章节 书有点老,但是里面一些概念还是总结比较到位 源码基于Spring-a ...
- SpringBoot笔记一
1 开始 1.1 spring介绍 Spring Boot使开发独立的,产品级别的基于Spring的应用变得非常简单,你只需"just run". 我们为Spring平台及第三方库 ...
随机推荐
- 解决PHP7无法监听9000端口问题/502错误解决办法
问题背景 昨晚帮配置nginx+php服务的时候,发生了一个奇怪的事情netstat -anp|grep 9000查看9000端口,一直没有监听,于是nginx无法通过fastcgi来代理php请求. ...
- mysql 面试题 查询出表中某字段的重复值
users 表中有 两个字段 id 和 name 表数据大概如下: id name 1 AAA 2 BBB 3 CCC 4 AAA 请写查 ...
- Unity初学者必备5款资源插件
Unity技术经理Sam Dogantimur为Unity初学者精心挑选和推荐了5款入门必备资源插件,涵盖游戏开发原型创作.着色器特效以及角色控制等,帮助Unity新手快速上手游戏开发. 我们将详细介 ...
- /etc/bashrc
[ "$PS1" = "\\s-\\v\\\$ " ] && PS1="[\[\e[34;1m\]\u@\[\e[0m\]\[\e[3 ...
- DOM 是什么,Document Object Model,文档对像模型
#为什么会想起来写这个 在写dynaTrace Ajax的时候,写到这个是个前端性能测试工具,这个工具能记录请求时间,前端页面渲染时间,DOM方法执行时间,以及JavaScript代码解析和执行时间. ...
- postgres开启慢查询日志
1.全局设置修改配置postgres.conf: log_min_duration_statement=5000 然后加载配置: postgres=# select pg_reload_conf() ...
- (7)Flask微电影之会员中心页面搭建
一.添加会员中心页面的路由 修改app/home/views.py内容,追加会员有关的5个路由: # coding:utf8 from . import home from flask import ...
- (转)SQLAlchemy入门和进阶
URL:https://zhuanlan.zhihu.com/p/27400862 https://www.cnblogs.com/mrchige/p/6389588.html---SQLAlchem ...
- Tensorflow问题
TypeError: 'urban' has type str, but expected one of: bytes 在前面添加"b"(例如,b'urban'),或者处理为var ...
- node.js使用markdown-it批量转md内容为html
代码如下: var fs = require('fs'); var MarkdownIt = require('markdown-it'), md = new MarkdownIt(); /* pag ...