@Aspect注解方式-AOP增强

使用@aspject进行aop增强处理,示例是类似于一个日志记录功能。

1.demo-web新增

152543_FZSG_2526015.png

  • Log
package com.company.aspectj;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 注解生命周期-运行时
 * 注解目标:方法
 */
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Log {
    String value() default "";
}
  • LogAspejctj
package com.company.aspectj;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@Aspect
public class LogAspectj {
    private static final Logger LOGGER = LoggerFactory.getLogger(LogAspectj.class);

    @AfterReturning(value = "@annotation(com.company.aspectj.Log)",returning = "ret")
    public void LogAfterReturning(JoinPoint joinPoint,Object ret){
        Object[] args = joinPoint.getArgs();
        LOGGER.info("方法入参:{}",args);
        LOGGER.info("返回值:{}",ret);
    }
}

 

2.配置

<!--@aspectj启动,子类代理-->
<aop:aspectj-autoproxy proxy-target-class="true"/>

<!--将定义aspectj扫入spring bean容器里(二选一)-->
<context:component-scan base-package="com.company.aspectj">
    <context:include-filter type="annotation" expression="org.aspectj.lang.annotation.Aspect"/>
</context:component-scan>
<!--<bean id="logAspectj" class="com.company.aspectj.LogAspectj"/>-->

 

3.实例测试

  • 将Log注解值UserController中qryUserById方法上
@RequestMapping("qryUserById")
@ResponseBody
@Log
public User qryUserById(Long id) throws DemoException{
    if(id == null){
        throw new DemoException("id为空");
    }

    return userService.qryUserById(id);
}
  • 地址栏=>http://localhost:8080/demo-web/user/qryUserById.do?id=1,console输出

154320_7HVX_2526015.png

 

转载于:https://my.oschina.net/u/2526015/blog/748600

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值