切入点表达式

本文详细介绍了如何使用方法执行表达式来指定特定类及其方法的调用方式,包括不同层级的通配符应用,适用于权限控制或AOP等场景。

exection([权限修饰符] [返回值类型] [类全路径] [方法名称] ([参数列表])) 其中返回值类型可省略

举例1 com.ztt.dao.BookDao 这个类中的 add()

exection(* com.ztt.dao.BookDao.add(..))

举例2 com.ztt.dao.BookDao 这个类中的所有方法

exection(* com.ztt.dao.BookDao.*(..))

举例3 com.ztt.dao 所有类中的所有方法

exection(* com.ztt.dao.*.*(..))

### 关于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]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值