Spring学习笔记之AOP配置篇(一)
[TOC]
1. 创建并声明一个切面
- 首先,创建一个类,添加
@Component
注解使其添加到IoC容器 - 然后,添加
@Aspect
注解,使其成为一个切面 - 最后,在配置文件里面,使用
<aop:aspectj-autoproxy></aop:aspectj-autoproxy>
来使其生效
2. 使用切面的通知
切面总共有6个通知类型,其中五个常用的为:前置通知、后置通知、返回通知、异常通知、环绕通知,一个不常用的为:引入通知。
而在五个常用的通知里,环绕通知功能最为强大,可以实现前四个的功能。
- 前置通知
- 添加
@Before
并指定注解参数:@Before(value = "execution(permission returnType packageName.className.methodName(parameters))")
函数参数为:
JoinPoint
- 后置通知
- 添加
@After
并指定注解参数:@After(value = "execution(permission returnType packageName.className.methodName(parameters))")
- 函数参数为:
JoinPoint
- 返回通知
- 添加
@AfterReturning
并指定注解参数:@AfterReturning(value = "execution(permission returnType packageName.className.methodName(parameters))",returning="result")
- 函数参数为:
JoinPoint, Object
- 异常通知
- 添加
@AfterThrowing
并指定注解参数:@AfterThrowing(value = "execution(permission returnType packageName.className.methodName(parameters))")
函数参数为:
JoinPoint
- 环绕通知
- 添加
@Around
并指定注解参数:@Around(value = "execution(permission returnType packageName.className.methodName(parameters))")
- 函数参数为:
ProceedingJoinPoint
函数返回值为:
Object
首先,上面代码中的名词为:
- permission为访问权限
- retrunType为返回值类型
- packageName为目标(切入对象)的包限定名
- className为目标的类名
- methodName为横切关注点(关注函数)的名字
- parameters为关注点传入的参数(只写类型即可)
其次,上面的注解都有一个隐藏的参数argNames
,此参数可确定传入参数的顺序
3. 定义切面的优先级
当一个横切关注点有多个切面时,我们可能会需要明确切面的执行顺序,此时我们就需要@Order
注解来完成这个工作。
- 首先,明确我们的切面执行顺序
- 然后,在切面的类注解上添加
@Order
注解 - 最后,为
@Order
注解指明参数,比如@Order(1)
注意:参数越小,优先级越高
4. 使用切入点表达式
可能在某种需求下,我们需要为一个关注点织入多个切面、多种通知,那么此时按照上面的做法,为每一个通知函数指定execution
会显得很麻烦,这个时候我们就会用到切入点表达式了。切入点表达式看上去就是一个加了注解的方法,使用时调用该方法就是了。
使用切入点表达式需要按照以下步骤:
- 选择本类或者新建一个专门的切面配置类来容纳切入点表达式
- 声明一个方法比如为
public void cut(){}
,添加@Pointcut
注解 - 像普通的那样为其指明参数
@Pointcut(value = "execution(permission returnType packageName.className.methodName(parameters))")
- 在本类中使用,则在原来通知的value属性上指定该函数即可,比如
@Before(value = "cut()")
- 在其他类中使用,则需要在方法名前加上该方法的所属类名,比如
@Before(value = "className.cut()")
所以,推荐在切面所在包下创建一个切面配置类,而不是所有包共用一个配置类。
需要注意的是,@Pointcut
注解没有returning
参数,故不能带返回值
Spring学习笔记之AOP配置篇(一)的更多相关文章
- Spring学习笔记之aop动态代理(3)
Spring学习笔记之aop动态代理(3) 1.0 静态代理模式的缺点: 1.在该系统中有多少的dao就的写多少的proxy,麻烦 2.如果目标接口有方法的改动,则proxy也需要改动. Person ...
- Spring学习笔记4——AOP
AOP 即 Aspect Oriented Program 面向切面编程 首先,在面向切面编程的思想里面,把功能分为核心业务功能,和周边功能. 所谓的核心业务,比如登陆,增加数据,删除数据都叫核心业务 ...
- Spring学习笔记2—AOP
1.AOP概念 AOP(Aspect Oriented Programming):面向切面编程,AOP能够将那些与业务无关,却为业务模块所共同调用的应用(例如事务处理.日志管理.权限控制等)封装起来, ...
- [Spring学习笔记 4 ] AOP 概念原理以及java动态代理
一.Spring IoC容器补充(1) Spring IoC容器,DI(依赖注入): 注入的方式:设值方法注入setter(属性注入)/构造子注入(构造函数传入依赖的对象)/字段注入Field(注解) ...
- Spring学习笔记之bean配置
1.命名bean 每个bean都有一个或者多个的的标识符.这些标识符必须在加载他们的容器里边唯一.一个bean经常有且只有一个标识符,但是如果需要超过一个的名字,可以考虑额外的别名. 基于xml的配置 ...
- Java框架spring 学习笔记(十八):事务管理(xml配置文件管理)
在Java框架spring 学习笔记(十八):事务操作中,有一个问题: package cn.service; import cn.dao.OrderDao; public class OrderSe ...
- 2.《Spring学习笔记-MVC》系列文章,讲解返回json数据的文章共有3篇,分别为:
转自:https://www.cnblogs.com/ssslinppp/p/4528892.html 个人认为,使用@ResponseBody方式来实现json数据的返回比较方便,推荐使用. 摘要 ...
- 1.《Spring学习笔记-MVC》系列文章,讲解返回json数据的文章共有3篇,分别为:
转自:https://www.cnblogs.com/ssslinppp/p/4528892.html [Spring学习笔记-MVC-3]SpringMVC返回Json数据-方式1:http://w ...
- 3.《Spring学习笔记-MVC》系列文章,讲解返回json数据的文章共有3篇,分别为:
转自:https://www.cnblogs.com/ssslinppp/p/4528892.html 概述 在文章:<[Spring学习笔记-MVC-3]SpringMVC返回Json数据-方 ...
随机推荐
- 【LeetCode】125. Valid Palindrome
题目: Given a string, determine if it is a palindrome, considering only alphanumeric characters and ig ...
- php的修改
修改数据: (1)如果不是有外键的表,那么修改就正常的进行修改页面和修改处理页面就可以,但是有了外键的表,在进行遍历时就要写相应的条件了. 例如,有张表中有性别,但是进行创建表时是用的0或1来表示的, ...
- [Android FrameWork 6.0源码学习] ViewGroup的addView函数分析
Android中整个的View的组装是采用组合模式. ViewGroup就相当与树根,各种Layout就相当于枝干,各种子View,就相当于树叶. 至于View类.我们就当它是个种子吧.哈哈! Vie ...
- ES6的十大特性和认知
---恢复内容开始--- ES6(ECMAScript2015)的出现,无疑给前端开发人员带来了新的惊喜,它包含了一些很棒的新特性,可以更加方便的实现很多复杂的操作,提高开发人员的效率.本文主要针对E ...
- CentOS上安装Hadoop2.7,添加数据节点,运行wordcount
安装hadoop的步骤比较繁琐,但是并不难. 在CentOS上安装Hadoop2.7 1. 安装 CentOS,注:图形界面并无必要 2. 在CentOS里设置静态IP,手工编辑如下4个文件 /etc ...
- 网络编程学习笔记(二)基于TCP的Socket编程
1.Socket:英文意思插座.两个Java应用程序可以通过一个双向的网络通信连接实现数据交换,这个双向链路的一端称为一个Socket. 2.Socket通常用来实现client-server(客户端 ...
- AngularJS实用基础知识---入门必备
前言 今天来和大家学习一下AngularJS-- AngularJS 通过新的属性和表达式扩展了 HTML. AngularJS 可以构建一个单一页面应用程序. AngularJS 学习起来非常简单. ...
- IE浏览器兼容
IE6下面元素的宽高小于16PX时 会默认以16PX显示(最小宽高) 解决办法:设置元素overflow:hidden; 当文字全是字母或数字时会超容器对溢出隐藏的样式失效, 解决办法:设置下父级 ...
- 优雅的封装ajax,含跨域
之前写过一篇 先定一个小目标,自己封装个ajax,是基于原生js的,也就是jquery中ajax的简化版本实现的思路.众所周知,jquery的ajax是项目中最常用的请求后台的方式,也算是封装的很完美 ...
- Unity3D拖尾组件在Ui界面下正常显示
在项目中Canvas下UI添加拖尾效果,会发现Ui完全遮挡住了拖尾. 如果要正常显示通常需要对Canvas进行设置,Render Mode 我这里用的是-Camera模式 其次要对Material 下 ...