錯誤信息:
nested exception is java.lang.IllegalStateException: It is illegal to call this method if the current request is not in asynchronous mode (i.e. isAsyncStarted() returns false)] with root cause:
錯誤原因:
joinPoint.getArgs()返回的數組中攜帶有Request(HttpServletRequest)或者Response(HttpServletResponse)對象,導致序列化異常。
解決方案:
//aop中獲取請求參數
Object[] args = joinPoint.getArgs();
Stream<?> stream = ArrayUtils.isEmpty(args) ? Stream.empty() : Arrays.asList(args);
List<Object> logArgs = stream.filter(arg -> (!(arg instanceof HttpServletRequest) && !(arg instanceof HttpServletResponse))).collect(Collectors.toList());
//過濾后序列化無異常
String string = JSON.toJSONString(logArgs);