zoukankan      html  css  js  c++  java
  • Spring AOP中pointcut expression表达式解析 及匹配多个条件

    转自:

    Spring AOP中pointcut expression表达式解析 及匹配多个条件

    Spring中事务控制相关配置:

      

     1 <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
     2     <property name="dataSource" ref="dataSource"/>
     3 </bean> 
     4 
     5 <tx:advice id="txAdvice" transaction-manager="txManager">
     6   <tx:attributes>
     7     <tx:method name="insert*" rollback-for="Exception"/>
     8     <tx:method name="update*" rollback-for="Exception"/>
     9     <tx:method name="delete*" rollback-for="Exception"/>
    10   </tx:attributes>
    11 </tx:advice>
    12 
    13 <aop:config>
    14   <aop:pointcut id="dbServiceOperation" expression="execution(* com.htt..*Service.*(..))"/>
    15   <aop:advisor advice-ref="txAdvice" pointcut-ref="dbServiceOperation"/>
    16 </aop:config>

      其中的“aop:pointcut”标签中"expression"的写法规则如下:

         execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern)  throws-pattern?)
        ret-type-pattern,name-pattern(param-pattern)是必须的.
        ret-type-pattern:标识方法的返回值,需要使用全路径的类名如java.lang.String,也可以为*表示任何返回值;
        name-pattern:指定方法名,*代表所有,例如set*,代表以set开头的所有方法.
        param-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.*(..))")

      在多个表达式之间使用 ||,or表示 或,使用 &&,and表示 与,!表示 非.例如:

         

    1 <aop:config>
    2       <aop:pointcut id="pointcut" expression="(execution(* com.ccboy.dao..*.find*(..))) or (execution(* com.ccboy.dao..*.query*(..)))"/>
    3       <aop:advisor advice-ref="jdbcInterceptor" pointcut-ref="pointcut" />
    4 </aop:config>
  • 相关阅读:
    activiti5.13 框架 数据库表结构说明
    c3p0详细配置
    linux+nginx+tomcat负载均衡,实现session同步
    Lvs+Keepalived+MySQL Cluster架设高可用负载均衡Mysql集群
    java jstack dump 线程 介绍 解释
    JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
    CheckStyle使用手册(一)
    checkstyle使用介绍
    memcache启动多个服务
    temp
  • 原文地址:https://www.cnblogs.com/Sunnor/p/6633982.html
Copyright © 2011-2022 走看看