自定义注解
springboot项目自定义注解
自定义注解 实现 统计方法执行时间
1定义注解#
代码示例
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface MethodTimer {
String value() default "";
}
2利用AOP实现注解#
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
import org.springframework.util.StopWatch;
/**
* 方法计时器 切面实现
*/
@Aspect
@Component
@Slf4j
public class MethodTimerAspect {
@Pointcut("@annotation(methodTimer)")
public void methodTimerLog(MethodTimer methodTimer) {
}
@Around(value = "methodTimerLog(methodTimer)", argNames = "proceedingJoinPoint,methodTimer")
public Object doAfter(ProceedingJoinPoint proceedingJoinPoint, MethodTimer methodTimer) throws Throwable {
StopWatch stopWatch = new StopWatch();
stopWatch.start();
Object proceed = proceedingJoinPoint.proceed();
stopWatch.stop();
log.info("方法名 : [{}], 执行时间: [{}MS], class-method : [{}]", methodTimer.value(),
stopWatch.getTotalTimeMillis(),
proceedingJoinPoint.getTarget().getClass().getName() + "." + proceedingJoinPoint.getSignature().getName());
return proceed;
}
}
3自定义注解的使用#
@MethodTimer( "上传数据")
@Override
public void upload(String serviceCode) {
}
4注解不生效#
在方法被其它方法内部调用时可能无法生效注解
@Service("superviseMedical")
@EnableAspectJAutoProxy(exposeProxy = true)
@Slf4j
public class DeptUpServiceImpl implements BaseUploadService<DeptInfo> {
@MethodTimer( "上传科室数据")
@Override
public void upload(String serviceCode) {
//method2();//不能直接调用,要使用代理才能 使自定义注解生效
(DeptUpServiceImpl)AopContext.currentProxy().method2()//这样使用代理调用函数 需要在类上添加 @EnableAspectJAutoProxy(exposeProxy = true)
}
@MethodTimer( "方法2")
void method2(){
- - -
}
}
作者:geekswg
出处:https://www.cnblogs.com/geekswg/p/15255611.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
本文来自博客园,作者:独行侠X,转载请注明原文链接:https://www.cnblogs.com/geekswg/p/15255611.html
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步