切面打印日志時,參數序列化異常。It is illegal to call this method if the current request is not in asynchron


切面打印日志時,參數序列化異常

異常信息:It is illegal to call this method if the current request is not in asynchron

原因

joinPoint.getArgs()返回的數組中攜帶有Request或者Response對象,導致序列化異常

 

 

 

解決

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);

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM