需求:
1、创建统一权限异常处理类,所有的权限异常走一个端口
2、根据请求方式不同返回不同数据,页面请求返回403未授权页面,ajax请求返回json数据
/**
* 授权权限异常
*/
@ExceptionHandler({UnauthorizedException.class})
public ModelAndView unauthorizedException(UnauthorizedException e, HttpServletRequest request) {
if (ServletUtils.isAjaxRequest(request))
{
ModelAndView modelAndView=new ModelAndView(new MappingJackson2JsonView());
modelAndView.addObject(AjaxResult.authError("您没有权限查看该数据"));
return modelAndView;
// return new ModelAndView(AjaxResult.authError("您没有权限查看该数据").toString());
}
else
{
return new ModelAndView("error/403");
}
}
其中:AjaxResult.authError是系统自定义的json通用返回对象,包含code、msg、data等通用字段自己可以自定义设置。
主要涉及到ModelAndView、MappingJackson2JsonView 通过传入的类型来控制是页面ORjson字符串