Spring aop切面实际应用 XML配置

Aspect:


/**
 * Created by Administrator on 2016/8/15.
 */
@Component
public class LogAspect {
    private final static Logger logger = LogUtil.get("access");
    @Autowired
    private LogTask logTask;

    public void afterReturning(JoinPoint joinPoint,Object retVal) {
        logTask.log((PrizeInvokeBean)joinPoint.getArgs()[0],(ExternalResponse<String>) retVal);
    }

    public void accessAfterReturning(JoinPoint joinPoint,Object retVal) {
        logger.info("DrawPrizeRequest =: {} , DrawPrizeResponse =: {}", (DrawPrizeRequest) joinPoint.getArgs()[0], (DrawPrizeResponse)retVal);
    }
}



aop-xml:

<?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:context="http://www.springframework.org/schema/context"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="
    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
    http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd
       http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.1.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd">


    <aop:config>
        <aop:pointcut id="lotteryLog"
                      expression="execution(* com.xxxxxx.xxxxx.invoke(..))"/>
        <aop:aspect id="check" ref="logAspect">
            <aop:after-returning pointcut-ref="lotteryLog"
                                 method="afterReturning" arg-names="joinPoint,retVal"  returning="retVal"/>
        </aop:aspect>
    </aop:config>

    <aop:config>
        <aop:pointcut id="accessLog"
                      expression="execution(* com.xxxxx.xxxxxx.drawPrize(..))"/>
        <aop:aspect id="access" ref="logAspect">
            <aop:after-returning pointcut-ref="accessLog"
                                 method="accessAfterReturning" arg-names="joinPoint,retVal"  returning="retVal"/>
        </aop:aspect>
    </aop:config>


    <aop:aspectj-autoproxy/>

</beans>


注解:

@Aspect
@Component
public class LogAspect {

    @Pointcut("execution(* com.xxxx.PrizeRemoteServiceImpl.create*(..))")
    public void create(){}

    @Pointcut("execution(* com.xxxxx.PrizeRemoteServiceImpl.update*(..))")
    public void update(){}

    @Before("create()")
    public void before(JoinPoint joinPoint){
        String appName = (String) ContextUtils.getLocalContext("CLIENT_APP");
        joinPoint.getTarget().getClass().getName();
        joinPoint.getArgs();
        joinPoint.getSignature().getName();
    }

    @AfterReturning(value="create()", argNames="rtv", returning="rtv")
    public void afterInsertMethod(JoinPoint jp, Object rtv) throws Throwable {

        Signature signature = jp.getSignature();
        log.debug("DeclaringType:" + signature.getDeclaringType());
        log.debug("DeclaringTypeName:" + signature.getDeclaringTypeName());
        log.debug("Modifiers:" + signature.getModifiers());
        log.debug("Name:" + signature.getName());
        log.debug("LongString:" + signature.toLongString());
        log.debug("ShortString:" + signature.toShortString());

        for (int i = 0; i < jp.getArgs().length; i++) {
            Object arg = jp.getArgs()[i];
            if(null != arg) {
                log.debug("Args:" + arg.toString());
            }
        }

        log.debug("Return:" + rtv);
    }


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值