切面打印日志時,參數序列化異常
異常信息:java.lang.IllegalStateException: It is illegal to call this method if the current request is not in asynchronous mode (i.e. isAsyncStarted() returns false)
原因
joinPoint.getArgs()返回的數組中攜帶有Request或者Response對象,導致序列化異常。
解決方案:去除Request或者Response對象
// JSONArray json=JSONArray.fromObject(joinPoint.getArgs()); Object[] args = joinPoint.getArgs(); Stream<?> stream = ArrayUtils.isEmpty(args) ? Stream.empty() : Arrays.stream(args); List<Object> logArgs = stream .filter(arg -> (!(arg instanceof HttpServletRequest) && !(arg instanceof HttpServletResponse))) .collect(Collectors.toList()); //過濾后序列化無異常 JSONArray json=JSONArray.fromObject(logArgs);
相關jar包:
import net.sf.json.JSONArray; import org.apache.commons.lang.ArrayUtils; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.Arrays; import java.util.List import java.util.stream.Collectors; import java.util.stream.Stream;