面向切面编程 —— Spring AOP

AOP(面向切面编程):是通过预编译方式和运行期间动态代理的方式实现在不修改源代码的情况下给程序动态添加统一功能的技术。

AOP 利用一种称为“横切”的技术,剖解开 封装对象 的内部,将影响多个类的公共行为封装到一个可重用的模块中,将其命名为Aspect切面。

AOP和OOP的关系:

OOP面向对象编程,主要是针对业务处理过程中的实体的属性和行为的抽象与封装,以获得更加清晰的逻辑单元。

AOP面向切面编程,主要是针对业务处理过程中的切面进行提取,它所面对的是处理过程中某个步骤或者阶段。

AOP可以说是OOP的补充和完善。OOP引入了封装,继承,多态等概念建立的一种对象的层次结构,用于某一个公共行为的集合。当分散的对象引入公共行为的时候,OOP显得无能为力,也就是说,OOP允许定义从上到下的关系,但是并不能定义从左到右的关系。将需求功能从不相关的类中分离出来,同时使多个类共用一个行为,一旦行为发生变化,不必修改多个类,只需要修改行为即可。

具体应用:

场景:对应用程序中提供给外部系统的多个faced接口的方法,提供统一的留痕操作(同时使多个服务类共用一个留痕行为)。

// 同一个拦截点切面执行顺序
@Order(QuestionAspectOrder.QUESTION_ASPECT_ORDET_SECOND)
@Aspect
@Component
public class QueryStatusRequestAspect {

    /**
     * 状态查询请求留痕切入点
     * 保全,理赔,订单,支付faced接口所有方法
     */
    @Pointcut("execution(public * com.xinmei.equery.facade.scenario.ClaimInfoFacade.*(..))" +
            "|| execution(public * com.xinmei.equery.facade.scenario.CSInfoFacade.*(..))" +
            "|| execution(public * com.xinmei.equery.facade.scenario.OrderStatusFacade.*(..))" +
            "|| execution(public * com.xinmei.equery.facade.scenario.PayStatusFacade.*(..))"
    )
    public void Pointcut(){}

    /**
     * 状态查询请求留痕
     */
    // 定义,切点前执行相关操作
    @Before(value = "Pointcut()")
    public void PointcutBefore(JoinPoint joinPoint){
        Object[] args = joinPoint.getArgs();
        QueryStatusParam queryStatusParam = (QueryStatusParam) args[0];
        logger.info("[状态查询请求留痕][请求参数:{}]", JSON.toJSONString(queryStatusParam));
        EqueryQuestionLogDTO equeryQuestionLogDTO = assembleEqueryQuestionLogByParam(queryStatusParam);
        equeryQuestionLogService.saveEqueryQuestionLog(equeryQuestionLogDTO);
        logger.info("[状态查询题请求留痕][落库成功]");
        if(queryStatusParam.getRequestQuestionUserModel().getRequestStatus() == "00"){
            String userName = StringUtils.isEmpty(queryStatusParam.getRequestQuestionUserModel().getRequestUserName())
                    ? queryStatusParam.getRequestQuestionUserModel().getRequestUserNickName()
                    : queryStatusParam.getRequestQuestionUserModel().getRequestUserName();
            throw new ValidationException("用户:" + userName
                    + "未获取到查询:" + queryStatusParam.getRequestQuestionUserModel().getRequestQuestionType() + "类型问题的权限");
        }
    }
}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring AOPSpring框架中的一个重要模块,它提供了面向切面编程AOP)的支持。AOP是一种编程思想,它可以在不改变原有代码的情况下,通过在程序运行时动态地将代码“织入”到现有代码中,从而实现对原有代码的增强。 Spring AOP提供了基于注解的AOP实现,使得开发者可以通过注解的方式来定义切面、切点和通知等相关内容,从而简化了AOP的使用。 下面是一个基于注解的AOP实现的例子: 1. 定义切面类 ```java @Aspect @Component public class LogAspect { @Pointcut("@annotation(Log)") public void logPointcut() {} @Before("logPointcut()") public void beforeLog(JoinPoint joinPoint) { // 前置通知 System.out.println("执行方法:" + joinPoint.getSignature().getName()); } @AfterReturning("logPointcut()") public void afterLog(JoinPoint joinPoint) { // 后置通知 System.out.println("方法执行完成:" + joinPoint.getSignature().getName()); } @AfterThrowing(pointcut = "logPointcut()", throwing = "ex") public void afterThrowingLog(JoinPoint joinPoint, Exception ex) { // 异常通知 System.out.println("方法执行异常:" + joinPoint.getSignature().getName() + ",异常信息:" + ex.getMessage()); } } ``` 2. 定义业务逻辑类 ```java @Service public class UserService { @Log public void addUser(User user) { // 添加用户 System.out.println("添加用户:" + user.getName()); } @Log public void deleteUser(String userId) { // 删除用户 System.out.println("删除用户:" + userId); throw new RuntimeException("删除用户异常"); } } ``` 3. 在配置文件中开启AOP ```xml <aop:aspectj-autoproxy/> <context:component-scan base-package="com.example"/> ``` 在这个例子中,我们定义了一个切面类LogAspect,其中通过@Aspect注解定义了一个切面,通过@Pointcut注解定义了一个切点,通过@Before、@AfterReturning和@AfterThrowing注解分别定义了前置通知、后置通知和异常通知。 在业务逻辑类中,我们通过@Log注解标注了需要增强的方法。 最后,在配置文件中,我们通过<aop:aspectj-autoproxy/>开启了AOP功能,并通过<context:component-scan>扫描了指定包下的所有组件。 这样,当我们调用UserService中的方法时,就会触发LogAspect中定义的通知,从而实现对原有代码的增强。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值