@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface AutoLog {
boolean inLog() default true;
boolean outLog() default true;
AutoLogLevelEnum level() default NONE;
}
/**
* projectName micro-util
* package com.open.util.handler.aspect
* classname AutoLogAspect
*
* description
*
*
* @author xxx
* @date 2021/7/2 18:00
*/
@Slf4j
@Aspect
@Component
@Order(Ordered.LOWEST_PRECEDENCE)
public class AutoLogAspect {
@Value("${open.advice.log.enabled:true}")
private boolean logEnabled;
@Value("${open.advice.log.logging.level:DEBUG}")
private AutoLogLevelEnum loggingLevel;
@Pointcut("@annotation(com.com.open.util.entity.annotation.AutoLog)")
private void allRequestMethod() {
}
@Before("allRequestMethod()")
public void doBefore(JoinPoint joinPoint) {
if (!logEnabled) {
return;
}
AutoLog autoLog = getAutoLog(joinPoint);
if (!autoLog.inLog()) {
return;
}
AutoLogLevelEnum logLevel = Objects.equals(autoLog.level(), NONE) ? loggingLevel : autoLog.level();
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
Optional.ofNullable(attributes).ifPresent(attribute -> {
HttpServletRequest request = attribute.getRequest();
request.getRequestURI();
request.getRemoteAddr();
logManage(logLevel, "Request uri [{}],remote addr {}", request.getRequestURI(), request.getRemoteAddr());
});
Object[] args = joinPoint.getArgs();
MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
Method method = methodSignature.getMethod();
logManage(logLevel, "In log method:[{}],args [{}]", method, args);
}
@AfterReturning(value = "allRequestMethod()", returning = "returnValue")
public void doAfter(JoinPoint joinPoint, Object returnValue) {
if (!logEnabled) {
return;
}
AutoLog aroundLogger = getAutoLog(joinPoint);
if (!aroundLogger.outLog()) {
return;
}
AutoLogLevelEnum logLevel = Objects.equals(aroundLogger.level(), NONE) ? loggingLevel : aroundLogger.level();
MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
Method method = methodSignature.getMethod();
logManage(logLevel, "Out log method:[{}],return [{}]", method, returnValue);
}
private AutoLog getAutoLog(JoinPoint point) {
MethodSignature methodSignature = (MethodSignature) point.getSignature();
Method method = methodSignature.getMethod();
AutoLog result = method.getAnnotation(AutoLog.class);
if (Objects.isNull(result)) {
return method.getDeclaringClass().getAnnotation(AutoLog.class);
}
return result;
}
private void logManage(AutoLogLevelEnum level, String market, Object... args) {
switch (level) {
case WARN:
log.warn(market, args);
break;
case DEBUG:
log.debug(market, args);
break;
default:
log.info(market, args);
}
}
}
java 通过注解和切面实现日志记录
文章来源:网络 版权归原作者所有,如涉及知识产权问题,请权利人联系我们,我们将立即处理.
推荐阅读 更多精彩内容
-
如题,执行 yarn logs -applicationId 命令时报错 : Exception in thread "main" org.apache.hadoop.yarn.exception.
西行寺え幽幽子 阅读 1013
-
Failed to import the site moduleTraceback (most recent call last): File "/usr/lib/python3.5/site.py"
一生所爱の赫萝 阅读 910
-
链接加上:-L../boost/stage/lib -pthread
上杉夏香 阅读 853
-
filelist.txtfile 'VID_20181219_214101.mp4'file 'VID_20181220_172414.mp4'命令ffmpeg -f concat -i fileli
一生所爱の赫萝 阅读 905
-
1. 烟台自驾游景点推荐在烟台待了这么多年,如果周边游的话可以免费把滨海路刷一遍,说起滨海路就不得不提17路公交,坐17路公交基本能把滨海路所有的景点都逛一遍。其他好的景点我只推荐天崮山,没错,你可能
冰雪殇璃陌梦 阅读 1033
-
1. 北京周边自驾游最美路线很不错的计划,去北京的半路上,可以在山东境内找一景点,回上海时可以走京石公路,沿路再找一景点休息参观。北京许多天津也是廊坊也是沧州的沧县著名清真寺衡水景县一个塔德州一个王陵
上杉夏香 阅读 1031
-
1. 川藏线自驾游开什么车好自驾318川藏线的话,我们可以开越野车,或者是吉普车都是可以的,最好不要开轿车。2. 川藏线自驾轿车合适吗可以。318国道是在中国华东、华中、西南地区的一条国道,起点为上海
血叶洛莉兰 阅读 877
-
1. 张家口坝上草原自驾游攻略坝上秋天夏天都温差大,九月去看秋色时,早晚随时零度。如果你是个摄影人需要早晚日出日落去创作,穿上羽绒就没错,别说秋天了,夏天早上都经常只有十度八度。配图第一张是我们在坝上
一生所爱の赫萝 阅读 1037
-
1. 西安周边自驾游排行榜西安周边自驾游好玩的地方有宝鸡关山牧场,秦岭沣峪口,蓝天县白鹿原影视城,泾阳县乐华娱乐城,泾阳茯茶小镇,兴平马嵬驿,兴平宏兴码头观光园,临潼区华清池,兵马俑,骊山,华阴县华山
一生所爱の赫萝 阅读 923