springboot 异常 org.springframework.expression.spel.SpelEvaluationException: EL1008E: Property or fiel

org.springframework.expression.spel.SpelEvaluationException: EL1008E: Property or field 'timestamp' cannot be found on object of type 'java.util.HashMap' - maybe not public?

使用LauItachi的项目WeChatPlatformApplication重现该异常,发现是因为项目中的GlobalExceptionHandler这个ControllerAdvice覆盖了默认的异常处理器

@ControllerAdvice
public class GlobalExceptionHandler {
    public static final String DEFAULT_ERROR_VIEW = "error";

    @ExceptionHandler(value = Exception.class)
    public ModelAndView defaultErrorHandler(HttpServletRequest req, Exception e) throws Exception {
        ModelAndView mav = new ModelAndView();
        mav.addObject("exception", e);
        mav.addObject("url", req.getRequestURL());
        mav.setViewName(DEFAULT_ERROR_VIEW);
        return mav;
    }
}

但是视图仍然是默认的视图名,仍然会使用ErrorMvcAutoConfiguration的defaultErrorView视图来进行渲染,在渲染是defaultErrorView中需要的placeholder中的属性值在上面的mav中没有,导致了上面的报错信息。完善上面的异常处理器即可。
顺便一提,默认的异常处理器是BasicErrorController,其中的model属性是全的,包含了默认视图中需要使用的全部信息。可以参考这个controller

 

mav.addObject("timestamp","2018-09-20 14:23:45:12");
        mav.addObject("exception", e);
        mav.addObject("url", req.getRequestURL());
        mav.addObject("error", "error");
        mav.addObject("status", "error");
        mav.addObject("message", "error");

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值