|
|
|
|
@ -48,6 +48,9 @@ public class LogAspect
|
|
|
|
|
/** 计算操作消耗时间 */
|
|
|
|
|
private static final ThreadLocal<Long> TIME_THREADLOCAL = new NamedThreadLocal<Long>("Cost Time");
|
|
|
|
|
|
|
|
|
|
/** 参数最大长度限制 */
|
|
|
|
|
private static final int PARAM_MAX_LENGTH = 2000;
|
|
|
|
|
|
|
|
|
|
@Autowired
|
|
|
|
|
private AsyncLogService asyncLogService;
|
|
|
|
|
|
|
|
|
|
@ -166,16 +169,16 @@ public class LogAspect
|
|
|
|
|
*/
|
|
|
|
|
private void setRequestValue(JoinPoint joinPoint, SysOperLog operLog, String[] excludeParamNames) throws Exception
|
|
|
|
|
{
|
|
|
|
|
Map<?, ?> paramsMap = ServletUtils.getParamMap(ServletUtils.getRequest());
|
|
|
|
|
String requestMethod = operLog.getRequestMethod();
|
|
|
|
|
Map<?, ?> paramsMap = ServletUtils.getParamMap(ServletUtils.getRequest());
|
|
|
|
|
if (StringUtils.isEmpty(paramsMap) && StringUtils.equalsAny(requestMethod, HttpMethod.PUT.name(), HttpMethod.POST.name(), HttpMethod.DELETE.name()))
|
|
|
|
|
{
|
|
|
|
|
String params = argsArrayToString(joinPoint.getArgs(), excludeParamNames);
|
|
|
|
|
operLog.setOperParam(StringUtils.substring(params, 0, 2000));
|
|
|
|
|
operLog.setOperParam(params);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
operLog.setOperParam(StringUtils.substring(JSON.toJSONString(paramsMap, excludePropertyPreFilter(excludeParamNames)), 0, 2000));
|
|
|
|
|
operLog.setOperParam(StringUtils.substring(JSON.toJSONString(paramsMap, excludePropertyPreFilter(excludeParamNames)), 0, PARAM_MAX_LENGTH));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@ -184,7 +187,7 @@ public class LogAspect
|
|
|
|
|
*/
|
|
|
|
|
private String argsArrayToString(Object[] paramsArray, String[] excludeParamNames)
|
|
|
|
|
{
|
|
|
|
|
String params = "";
|
|
|
|
|
StringBuilder params = new StringBuilder();
|
|
|
|
|
if (paramsArray != null && paramsArray.length > 0)
|
|
|
|
|
{
|
|
|
|
|
for (Object o : paramsArray)
|
|
|
|
|
@ -194,15 +197,20 @@ public class LogAspect
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
String jsonObj = JSON.toJSONString(o, excludePropertyPreFilter(excludeParamNames));
|
|
|
|
|
params += jsonObj.toString() + " ";
|
|
|
|
|
params.append(jsonObj).append(" ");
|
|
|
|
|
if (params.length() >= PARAM_MAX_LENGTH)
|
|
|
|
|
{
|
|
|
|
|
return StringUtils.substring(params.toString(), 0, PARAM_MAX_LENGTH);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
{
|
|
|
|
|
log.error("请求参数拼装异常 msg:{}, 参数:{}", e.getMessage(), paramsArray, e);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return params.trim();
|
|
|
|
|
return params.toString();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|