Spring AOP在pointcut expression解析表达式 并匹配多个条件

简介:
Pointcut 方法是那些需要运行"AOP",由"Pointcut Expression"为了描述叙事.
Pointcut以下方法可以通过定义任&& || 和!组合方式. 
args()
@args()
execution()
this()
target()
@target()
within()
@within()
@annotation
当中 execution  是用的最多的,其格式为:
execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern)throws-pattern?

)
returning type pattern,name pattern, and parameters pattern是必须的.
ret-type-pattern:能够为*表示不论什么返回值,全路径的类名等.
name-pattern:指定方法名,*代表所以,set*,代表以set开头的全部方法.
parameters pattern:指定方法參数(声明的类型),(..)代表全部參数,(*)代表一个參数,(*,String)代表第一个參数为不论什么值,第二个为String类型.
举例说明:
随意公共方法的运行:
execution(public * *(..))
不论什么一个以“set”開始的方法的运行:
execution(* set*(..))
AccountService 接口的随意方法的运行:
execution(* com.xyz.service.AccountService.*(..))
定义在service包里的随意方法的运行:
execution(* com.xyz.service.*.*(..))
定义在service包和全部子包里的随意类的随意方法的运行:
execution(* com.xyz.service..*.*(..))
定义在pointcutexp包和全部子包里的JoinPointObjP2类的随意方法的运行:
execution(* com.test.spring.aop.pointcutexp..JoinPointObjP2.*(..))")

***> 最靠近(..)的为方法名,靠近.*(..))的为类名或者接口名,如上例的JoinPointObjP2.*(..))

<aop:config>
  <aop:pointcut expression="execution(* com.travelsky.ccboy.dao..*.find*(..))||  execution(* com.travelsky.ccboy.dao..*.query*(..))"
   id="findCachePointcut" />
  <aop:advisor advice-ref="jdbcInterceptor" pointcut-ref="findCachePointcut" />
</aop:config>
在多个表达式之间使用 ||,or表示 ,使用 &&,and表示 

表示 .
 
上面的代码也能够改写成
<aop:config>
  <aop:pointcut expression="(execution(* com.travelsky.ccboy.dao..*.find*(..))) or(execution(* com.travelsky.ccboy.dao..*.query*(..)))"
   id="findCachePointcut" />
  <aop:advisor advice-ref="jdbcInterceptor" pointcut-ref="findCachePointcut" />
</aop:config>
 
注意上面两中方法的不同点出了 将 || 改成了 or ,还有就是 每一个execution都被()包括起来,建议为了区分不同的表达式 最好都是用()包装。



pointcutexp包里的随意类.
within(com.test.spring.aop.pointcutexp.*)
pointcutexp包和全部子包里的随意类.
within(com.test.spring.aop.pointcutexp..*)
实现了Intf接口的全部类,假设Intf不是接口,限定Intf单个类.
this(com.test.spring.aop.pointcutexp.Intf)
***> 当一个实现了接口的类被AOP的时候,用getBean方法必须cast为接口类型,不能为该类的类型.

带有@Transactional标注的全部类的随意方法.
@within(org.springframework.transaction.annotation.Transactional)
@target(org.springframework.transaction.annotation.Transactional)
带有@Transactional标注的随意方法.
@annotation(org.springframework.transaction.annotation.Transactional)
***> @within和@target针对类的注解,@annotation是针对方法的注解

參数带有@Transactional标注的方法.
@args(org.springframework.transaction.annotation.Transactional)
參数为String类型(执行是决定)的方法.
args(String)

Pointcut 能够通过Java注解和XML两种方式配置,例如以下所看到的:

<bean id="bravemandao" class="com.test.dao.BraveManDao">
		<property name="barveman" ref="braveman"></property>
	</bean>
	<bean id="braveman" class="com.test.bean.BraveMan">
		
	</bean>
	<bean id="minstrel" class="com.test.bean.Minstrel"></bean>
	<aop:config>
		<aop:aspect ref="minstrel">
			<aop:pointcut expression="execution(* *.test(..))" id="say"/>
			<aop:before pointcut-ref="say" method="singBeforeSay"/>
			<aop:after pointcut-ref="say" method="singAfterSay"/>
		</aop:aspect>
	</aop:config>



package com.test.bean;

public class Minstrel {
	public void singBeforeSay(){
		System.out.println("before say!!!");
	}
	public void singAfterSay(){
		System.out.println("after say!!!");
	}
}

public class BraveManDao {
	BraveMan braveman;

	public BraveMan getBarveman() {
		return braveman;
	}

	public void setBarveman(BraveMan braveman) {
		this.braveman = braveman;
	}
	public void test(){
		braveman.say();
	}
}


版权声明:本文博客原创文章。博客,未经同意,不得转载。






本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/4664177.html,如需转载请自行联系原作者


相关文章
|
4月前
|
负载均衡 监控 Java
Spring Cloud Gateway 全解析:路由配置、断言规则与过滤器实战指南
本文详细介绍了 Spring Cloud Gateway 的核心功能与实践配置。首先讲解了网关模块的创建流程,包括依赖引入(gateway、nacos 服务发现、负载均衡)、端口与服务发现配置,以及路由规则的设置(需注意路径前缀重复与优先级 order)。接着深入解析路由断言,涵盖 After、Before、Path 等 12 种内置断言的参数、作用及配置示例,并说明了自定义断言的实现方法。随后重点阐述过滤器机制,区分路由过滤器(如 AddRequestHeader、RewritePath、RequestRateLimiter 等)与全局过滤器的作用范围与配置方式,提
Spring Cloud Gateway 全解析:路由配置、断言规则与过滤器实战指南
|
4月前
|
缓存 安全 Java
Spring Security通用权限管理模型解析
Spring Security作为Spring生态的核心安全框架,结合RBAC与ACL权限模型,基于IoC与AOP构建灵活、可扩展的企业级权限控制体系,涵盖认证、授权流程及数据库设计、性能优化等实现策略。
372 0
|
4月前
|
缓存 安全 Java
Spring Security权限管理解析
Spring Security是Spring生态中的核心安全框架,采用认证与授权分离架构,提供高度可定制的权限管理方案。其基于过滤器链实现认证流程,通过SecurityContextHolder管理用户状态,并结合RBAC模型与动态权限决策,支持细粒度访问控制。通过扩展点如自定义投票器、注解式校验与前端标签,可灵活适配多租户、API网关等复杂场景。结合缓存优化与无状态设计,适用于高并发与前后端分离架构。
399 0
|
4月前
|
人工智能 Java 开发者
【Spring】原理解析:Spring Boot 自动配置
Spring Boot通过“约定优于配置”的设计理念,自动检测项目依赖并根据这些依赖自动装配相应的Bean,从而解放开发者从繁琐的配置工作中解脱出来,专注于业务逻辑实现。
1776 0
|
4月前
|
SQL Java 数据库连接
Spring Data JPA 技术深度解析与应用指南
本文档全面介绍 Spring Data JPA 的核心概念、技术原理和实际应用。作为 Spring 生态系统中数据访问层的关键组件,Spring Data JPA 极大简化了 Java 持久层开发。本文将深入探讨其架构设计、核心接口、查询派生机制、事务管理以及与 Spring 框架的集成方式,并通过实际示例展示如何高效地使用这一技术。本文档约1500字,适合有一定 Spring 和 JPA 基础的开发者阅读。
522 0
|
3月前
|
XML Java 数据格式
《深入理解Spring》:AOP面向切面编程深度解析
Spring AOP通过代理模式实现面向切面编程,将日志、事务等横切关注点与业务逻辑分离。支持注解、XML和编程式配置,提供五种通知类型及丰富切点表达式,助力构建高内聚、低耦合的可维护系统。
|
3月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
4月前
|
Java 数据库 数据安全/隐私保护
Spring Boot四层架构深度解析
本文详解Spring Boot四层架构(Controller-Service-DAO-Database)的核心思想与实战应用,涵盖职责划分、代码结构、依赖注入、事务管理及常见问题解决方案,助力构建高内聚、低耦合的企业级应用。
1097 1
|
4月前
|
Kubernetes Java 微服务
Spring Cloud 微服务架构技术解析与实践指南
本文档全面介绍 Spring Cloud 微服务架构的核心组件、设计理念和实现方案。作为构建分布式系统的综合工具箱,Spring Cloud 为微服务架构提供了服务发现、配置管理、负载均衡、熔断器等关键功能的标准化实现。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
534 0
|
4月前
|
安全 Java 数据安全/隐私保护
Spring Security 核心技术解析与实践指南
本文档深入探讨 Spring Security 框架的核心架构、关键组件和实际应用。作为 Spring 生态系统中负责安全认证与授权的关键组件,Spring Security 为 Java 应用程序提供了全面的安全服务。本文将系统介绍其认证机制、授权模型、过滤器链原理、OAuth2 集成以及最佳实践,帮助开发者构建安全可靠的企业级应用。
296 0

推荐镜像

更多
  • DNS