切入点表达式

切入点表达式写法:

常规写法

    红色字体按下面的举例套进去就可以,注意参数格式的黑色符号:空格,括号,点都是必须的

  参数格式:execution("修饰符 返回值类型  .   . 方法名参数) throws异常")

  修饰符(举例):一般省略

     *       任意

    public     公共访问

  返回值(举例):

    void       无返回值

    String      返回值是字符串类型

    *       返回值任意

  包(举例):      

    com.xx.user.dao    固定包

    com.xx.*.dao          com.xx下的任意包中的dao包

    com.xx.user.dao.  包括dao下所有子包中

  类(举例):

    UserDaoImpl   具体类

    User*         以User开头类

    *User         以User结尾类

    *           任意类

  方法(举例):

    addUser      具体方法

    *        任意方法

    *User      以add结尾方法

    add*       以add开头方法

  参数(举例):

      空      无参

    ..       任意参数

      String,int     1个String和1个int类型的参数

    int        1个int类型参数

  throws,可省略一般不写

以注解为切入点表达式写法

@annotation(注解全类名)

### 关于AOP切入点表达式的语法与示例 #### 切入点表达式概述 Spring AOP 中的切入点表达式是一种强大的工具,用于精确定义程序中的哪些连接点(Join Point)需要执行通知逻辑。这些表达式基于 AspectJ 的语法构建,能够灵活地匹配特定的方法签名或其他条件。 #### 支持的切入点指示符 Spring AOP 提供了多种切入点指示符来满足不同的需求。常见的有 `execution`、`within` 和 `args` 等[^2]。其中最常用的是 `execution` 表达式,它可以用来匹配方法的执行。 --- #### 示例:使用 `execution` 定义切入点 下面是一个典型的切入点表达式示例: ```java @Before("execution(* com.example.service.*.*(..))") public void beforeAdvice(JoinPoint joinPoint) { System.out.println("Method " + joinPoint.getSignature().getName() + " is executing."); } ``` 此表达式的作用是拦截 `com.example.service` 包下所有类的所有方法调用,并在其之前打印一条日志消息。具体解释如下: - `*`: 返回任意类型的值。 - `com.example.service.*`: 指定包下的任何类。 - `*(..)`: 方法名可以是任意字符,参数列表也可以为空或包含任意数量的参数。 --- #### 使用通配符扩展表达式 可以通过通配符进一步细化切入点的定义。例如: ```java @AfterReturning(pointcut = "execution(void com.Demo.service.impl.DeptServiceImpl.delete(java.lang.Integer))", returning = "result") public void afterDeleteAdvice(Object result) { System.out.println("The delete method has been executed and returned: " + result); } ``` 在此示例中,切入点仅限于 `DeptServiceImpl` 类中的 `delete(Integer)` 方法[^3]。 --- #### 配置异常通知 如果希望在某个方法抛出异常时触发通知,则可以使用 `<aop:after-throwing>` 或者相应的注解形式。例如: ```java @AfterThrowing(pointcut = "execution(* com.example.service.UserService.addUser(User))", throwing = "ex") public void logException(Exception ex) { System.err.println("An exception occurred while adding user: " + ex.getMessage()); } ``` 这里的 `pointcut` 参数指定了切入点表达式,而 `throwing` 参数则绑定了具体的异常对象[^4]。 --- #### 更复杂的表达式组合 除了单一的 `execution` 外,还可以结合其他关键词创建更精细的过滤器。比如限定某些包内的操作或者根据传参类型筛选目标函数: ```java @Around("@annotation(com.example.annotations.LogExecutionTime)") public Object aroundLogExecutionTime(ProceedingJoinPoint pjp) throws Throwable { long startTime = System.currentTimeMillis(); try { return pjp.proceed(); // 执行被代理的方法 } finally { long elapsedTime = System.currentTimeMillis() - startTime; System.out.println(pjp.getSignature() + " took " + elapsedTime + " ms"); } } ``` 这里展示了如何通过自定义注解作为切入点的一部分[^2]。 --- #### 解析实际案例 考虑这样一个场景——监控服务层所有公开 API 的性能表现: ```java @Aspect @Component public class PerformanceMonitor { @Around("execution(public * com.myapp.service..*(..)) && args(user, ..)") public Object monitorServiceMethods(ProceedingJoinPoint jp, User user) throws Throwable { String methodName = jp.getSignature().toShortString(); StopWatch watch = new StopWatch(methodName); try { watch.start(); return jp.proceed(); } finally { watch.stop(); logger.info("{} completed in {}ms with argument {}", methodName, watch.getTotalTimeMillis(), user.getName()); } } } ``` 上述代码片段说明了一个复杂的应用实例,即只针对带有特定参数的服务端口进行耗时统计[^5]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值