com.suchtool.nicelog.aspect.LogParamProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of nicelog-spring-boot-starter Show documentation
Show all versions of nicelog-spring-boot-starter Show documentation
collect log automatically for SpringBoot project
The newest version!
package com.suchtool.nicelog.aspect;
import com.suchtool.nicelog.annotation.NiceLog;
import com.suchtool.nicelog.annotation.NiceLogOperation;
import com.suchtool.nicelog.constant.EntryTypeEnum;
import com.suchtool.nicelog.util.log.NiceLogUtil;
import com.suchtool.nicetool.util.base.JsonUtil;
import com.suchtool.nicetool.util.reflect.MethodUtil;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.context.expression.MethodBasedEvaluationContext;
import org.springframework.core.DefaultParameterNameDiscoverer;
import org.springframework.core.ParameterNameDiscoverer;
import org.springframework.expression.EvaluationContext;
import org.springframework.expression.ExpressionParser;
import org.springframework.expression.spel.standard.SpelExpressionParser;
import org.springframework.util.CollectionUtils;
import org.springframework.util.StringUtils;
import org.springframework.validation.BindingResult;
import org.springframework.web.multipart.MultipartFile;
import java.lang.reflect.Method;
import java.util.Arrays;
import java.util.Collection;
import java.util.Map;
/**
* 日志参数提供者
*/
public interface LogParamProvider {
ExpressionParser PARSER = new SpelExpressionParser();
ParameterNameDiscoverer NAME_DISCOVERER = new DefaultParameterNameDiscoverer();
EntryTypeEnum provideEntryType();
default String provideEntry(Method method) {
return provideClassTag(method);
}
default String provideEntryClassTag(Method method) {
return provideClassTag(method);
}
default String provideEntryMethodTag(Method method) {
return provideMethodTag(method);
}
default String provideClassName(Method method) {
return method.getDeclaringClass().getName();
}
/**
* 先取@NiceLog的value,若没有再从原注解拼接tag
*/
default String provideClassTag(Method method) {
String classTag = null;
Class> declaringClass = method.getDeclaringClass();
if (declaringClass.isAnnotationPresent(NiceLog.class)) {
NiceLog niceLog = declaringClass.getAnnotation(NiceLog.class);
classTag = niceLog.value();
}
if (!StringUtils.hasText(classTag)) {
if (EntryTypeEnum.CONTROLLER.equals(provideEntryType())
&& declaringClass.isAnnotationPresent(Api.class)) {
Api api = declaringClass.getAnnotation(Api.class);
String[] tags = api.tags();
String value = api.value();
String tagJoin = String.join("+", tags);
if (tags.length > 0) {
classTag = tagJoin;
} else {
classTag = value;
}
} else if (EntryTypeEnum.FEIGN.equals(provideEntryType())) {
FeignClient feignClient = declaringClass.getAnnotation(FeignClient.class);
classTag = feignClient.value();
}
}
return classTag;
}
default String provideMethodName(Method method) {
return method.getName();
}
/**
* 先从原注解拼接tag,没有再取@NiceLog的value
*/
default String provideMethodTag(Method method) {
String methodTag = null;
if (method.isAnnotationPresent(NiceLogOperation.class)) {
methodTag = method.getAnnotation(NiceLogOperation.class).value();
}
if (!StringUtils.hasText(methodTag)) {
Class> declaringClass = method.getDeclaringClass();
if (declaringClass.isAnnotationPresent(NiceLog.class)) {
NiceLog niceLog = declaringClass.getAnnotation(NiceLog.class);
methodTag = niceLog.value();
}
}
if (!StringUtils.hasText(methodTag)) {
if (EntryTypeEnum.CONTROLLER.equals(provideEntryType())
&& method.isAnnotationPresent(ApiOperation.class)) {
methodTag = method.getAnnotation(ApiOperation.class).value();
}
}
return methodTag;
}
/**
* 如果param不为空则取它;否则根据method和args去解析
*/
default String provideParam(String param, Method method, Object[] args) {
String finalParam = null;
if (StringUtils.hasText(param)) {
finalParam = param;
} else {
try {
Collection> ignoreLogClassList = Arrays.asList(
BindingResult.class, MultipartFile.class);
Map map = MethodUtil.parseParam(method, args, ignoreLogClassList);
if (!CollectionUtils.isEmpty(map)) {
finalParam = JsonUtil.toJsonString(map);
}
} catch (Throwable e) {
NiceLogUtil.createBuilder()
.mark("nicelog解析参数失败")
.throwable(e)
.error();
}
}
return finalParam;
}
default String provideBusinessNo(Method method, Object[] args) {
String businessNo = null;
if (method.isAnnotationPresent(NiceLogOperation.class)) {
NiceLogOperation niceLogOperation = method.getAnnotation(NiceLogOperation.class);
String businessNoSpEL = niceLogOperation.businessNoSpEL();
if (StringUtils.hasText(businessNoSpEL)) {
EvaluationContext context = new MethodBasedEvaluationContext(
null, method, args, NAME_DISCOVERER);
businessNo = PARSER.parseExpression(businessNoSpEL).getValue(context, String.class);
}
}
return businessNo;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy