首页 > 编程语言 > 详细

java.lang.IllegalStateException: It is illegal to call this method if the current request is not in asynchronous mode (i.e. isAsyncStarted() returns false)

时间:2020-06-04 21:32:10      阅读:640      评论:0      收藏:0      [点我收藏+]

切面打印日志时,参数序列化异常
异常信息: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;

 

java.lang.IllegalStateException: It is illegal to call this method if the current request is not in asynchronous mode (i.e. isAsyncStarted() returns false)

原文:https://www.cnblogs.com/penghq/p/13045825.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!