zoukankan      html  css  js  c++  java
  • 切面AOP的切点@Pointcut用法

    格式:

    execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern)throws-pattern?) 

    括号中各个pattern分别表示:

    • 修饰符匹配(modifier-pattern?)
    • 返回值匹配(ret-type-pattern)可以为*表示任何返回值,全路径的类名等
    • 类路径匹配(declaring-type-pattern?)
    • 方法名匹配(name-pattern)可以指定方法名 或者 *代表所有, set* 代表以set开头的所有方法
    • 参数匹配((param-pattern))可以指定具体的参数类型,多个参数间用“,”隔开,各个参数也可以用“*”来表示匹配任意类型的参数,如(String)表示匹配一个String参数的方法;(*,String) 表示匹配有两个参数的方法,第一个参数可以是任意类型,而第二个参数是String类型;可以用(..)表示零个或多个任意参数
    • 异常类型匹配(throws-pattern?)
    • 其中后面跟着“?”的是可选项

    现在来看看几个例子:

    //表示匹配所有方法  
    1)execution(* *(..))  
    //表示匹配com.savage.server.UserService中所有的公有方法  
    2)execution(public * com. savage.service.UserService.*(..))  
    //表示匹配com.savage.server包及其子包下的所有方法 
    3)execution(* com.savage.server..*.*(..))  

    在Spring 2.0中,Pointcut的定义包括两个部分:Pointcut表示式(expression)和Pointcut签名(signature)

    //Pointcut表示式
    @Pointcut("execution(* com.savage.aop.MessageSender.*(..))")
    //Point签名
    private void log(){} 
    然后要使用所定义的Pointcut时,可以指定Pointcut签名
    如下:
    //执行方法之前,进入切点
    @Before("og()")

    这种使用方式等同于以下方式,直接定义execution表达式使用

    //执行方法之前进入切点
    @Before("execution(* com.savage.aop.MessageSender.*(..))")

    Pointcut定义时,还可以使用&&、||、! 这三个运算

    //切点1
    @Pointcut("execution(* com.savage.aop.MessageSender.*(..))")
    private void logSender(){}
    //切点2
    @Pointcut("execution(* com.savage.aop.MessageReceiver.*(..))")
    private void logReceiver(){}
    //或注解的切点
    @Pointcut("logSender() || logReceiver()")
    private void logMessage(){}

    这个例子中,logMessage()将匹配任何MessageSender和MessageReceiver中的任何方法。


    还可以将一些公用的Pointcut放到一个类中,以供整个应用程序使用,如下:

    package com.savage.aop;
    
    import org.aspectj.lang.annotation.*;
    
    public class Pointcuts {
    @Pointcut("execution(* *Message(..))")
    public void logMessage(){}
    
    @Pointcut("execution(* *Attachment(..))")
    public void logAttachment(){}
    
    @Pointcut("execution(* *Service.*(..))")
    public void auth(){}
    }

    在使用上面定义Pointcut时,指定完整的类名加上Pointcut签名就可以了,如:

    package com.savage.aop;
    
    import org.aspectj.lang.JoinPoint;
    import org.aspectj.lang.annotation.*;
    
    @Aspect
    public class LogBeforeAdvice {
    @Before("com.sagage.aop.Pointcuts.logMessage()")
    public void before(JoinPoint joinPoint) {
    System.out.println("Logging before " + joinPoint.getSignature().getName());
    }
    }

    当基于XML Sechma实现Advice时,如果Pointcut需要被重用,可以使用<aop:pointcut></aop:pointcut>来声明Pointcut,然后在需要使用这个Pointcut的地方,用pointcut-ref引用就行了,如:

    <aop:config>
      <aop:pointcut id="log" expression="execution(* com.savage.simplespring.bean.MessageSender.*(..))"/>
      <aop:aspect id="logging" ref="logBeforeAdvice">
        <aop:before pointcut-ref="log" method="before"/>
        <aop:after-returning pointcut-ref="log" method="afterReturning"/>
      </aop:aspect>
    </aop:config>

    另外,除了execution表示式外,还有within、this、target、args等Pointcut表示式

    ----------------------------------------------------------------------------------------------------------

    原文链接:https://www.cnblogs.com/liaojie970/p/7883687.html

    切点
  • 相关阅读:
    Git常用命令总结
    自己动手做一个vue组件,并上传npm
    详解树状结构图 vue-org-tree
    npm依赖之tooljs、requestjs
    本地服务器热更新 插件 live-server
    VUE项目引入第三方依赖报错 Uncaught SyntaxError: Unexpected token <
    npm安装依赖报 npm ERR! code Z_BUF_ERROR npm ERR! errno -5 npm ERR! zlib: unexpected end of file 这个错误解决方案
    关于Vue-$router传参出现刷新页面或者返回页面丢失数据的问题
    Vue自行封装常用组件-倒计时
    Vue自行封装常用组件-文本提示
  • 原文地址:https://www.cnblogs.com/hongmoshui/p/10749990.html
Copyright © 2011-2022 走看看