Spring框架学习记录之环绕增强

本文介绍了Spring框架中环绕增强的概念及其实现方式。通过具体的代码示例,展示了如何定义环绕增强处理类及其配置,实现对业务方法的前置、后置及异常处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Spring框架学习记录之环绕增强


概念:图片来源于网络:

 

示例:环绕增强

定义的接口

public interface UserService {
   
public void addNewUser(User user);
}

 

接口的实现类调用dao层的实现的方法

public class UserDaoImpl implements UserDao {

   
public void save(User user) {
      
// 这里并未实现完整的数据库操作,仅为说明问题
      
System.out.println("保存用户信息到数据库");
   
}
}

 

环绕增强处理类

/**
 * 
环绕增强处理类
 */
public class AroundLogger {
    
private static Logger log Logger.getLogger(AroundLogger.class);

    
public Object aroundLogger(ProceedingJoinPoint jp) throws Throwable {
        
log.info("调用+ jp.getTarget() + "+ jp.getSignature() +
                
"方法,方法参数: " Arrays.toString(jp.getArgs()));


        
try {
            
Object result = jp.proceed();
            
log.info("调用 " + jp.getTarget() +  "
                    
+ jp.getSignature().getName() + 方法。方法返回值:+ result);
            
return result;
        
catch (Throwable throwable) {
            
log.error(jp.getSignature().getName() + "方法发生异常+ throwable);
            
throw throwable;
        
finally {
            
log.info(jp.getSignature().getName() + "方法执行结束");
        
}
    }
}

 

环绕增强处理类的配置

<?xml version="1.0" encoding="UTF-8"?>
<beans 
xmlns="http://www.springframework.org/schema/beans"
       
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       
xmlns:aop="http://www.springframework.org/schema/aop"
       
xsi:schemaLocation="http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
   http://www.springframework.org/schema/aop
   http://www.springframework.org/schema/aop/spring-aop-3.2.xsd"
>
    <bean 
id="dao" class="dao.impl.UserDaoImpl"></bean>
    <bean 
id="userService" class="service.impl.UserServiceImpl">
        <property 
name="dao" ref="dao"></property>
    </bean>
    
<!-- 声明增强方法所在的Bean -->
    
<bean id="aroundLogger" class="aop.AroundLogger"></bean>
    
<!-- 配置切面 -->
    
<aop:config>
        
<!-- 定义切入点 -->
        
<aop:pointcut id="pointcut" expression="execution(* service.UserService.*(..))" />
        
<!-- 织入环绕增强处理 -->
        
<aop:aspect ref="aroundLogger">
            
<!--aop:around 为环绕增强的标签元素,引入到切入点 pointcut-->
            
<aop:around method="aroundLogger" pointcut-ref="pointcut"/>
        </
aop:aspect>
    </
aop:config>
</beans>

 

日志输出结果

* [INFO] 2018-05-29 22:26:37,120 aop.AroundLogger - 调用service.impl.UserServiceImpl@31368b99void service.UserService.addNewUser(User)方法,方法参数: [entity.User@43195e57]
*     
保存用户信息到数据库
*     [INFO] 2018-05-29 22:26:37,121 aop.AroundLogger - 
调用 service.impl.UserServiceImpl@31368b99  addNewUser 方法。方法返回值:null
*     [INFO] 2018-05-29 22:26:37,121 aop.AroundLogger - addNewUser
方法执行结束

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值