| package com.ruoyi.common.security.handler; | 
|   | 
| import javax.naming.SizeLimitExceededException; | 
| import javax.servlet.http.HttpServletRequest; | 
|   | 
| import com.ruoyi.common.core.domain.R; | 
| import com.ruoyi.common.core.exception.auth.NotLoginException; | 
| import com.ruoyi.common.core.exception.user.UserAppletException; | 
| import org.apache.commons.fileupload.FileUploadBase; | 
| import org.slf4j.Logger; | 
| import org.slf4j.LoggerFactory; | 
| import org.springframework.beans.factory.annotation.Value; | 
| import org.springframework.validation.BindException; | 
| import org.springframework.web.HttpRequestMethodNotSupportedException; | 
| import org.springframework.web.bind.MethodArgumentNotValidException; | 
| import org.springframework.web.bind.annotation.ExceptionHandler; | 
| import org.springframework.web.bind.annotation.RestControllerAdvice; | 
| import com.ruoyi.common.core.constant.HttpStatus; | 
| import com.ruoyi.common.core.exception.DemoModeException; | 
| import com.ruoyi.common.core.exception.InnerAuthException; | 
| import com.ruoyi.common.core.exception.ServiceException; | 
| import com.ruoyi.common.core.exception.auth.NotPermissionException; | 
| import com.ruoyi.common.core.exception.auth.NotRoleException; | 
| import com.ruoyi.common.core.utils.StringUtils; | 
| import com.ruoyi.common.core.web.domain.AjaxResult; | 
| import org.springframework.web.multipart.MaxUploadSizeExceededException; | 
| import org.springframework.web.multipart.MultipartException; | 
|   | 
| /** | 
|  * 全局异常处理器 | 
|  * | 
|  * @author ruoyi | 
|  */ | 
| @RestControllerAdvice | 
| public class GlobalExceptionHandler { | 
|     private static final Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class); | 
|      | 
|     @Value("${spring.servlet.multipart.max-file-size:50MB}") | 
|     private String maxFileSize; | 
|     @Value("${spring.servlet.multipart.max-request-size:100MB}") | 
|     private String maxRequestSize; | 
|      | 
|      | 
|     /** | 
|      * 权限码异常 | 
|      */ | 
|     @ExceptionHandler(NotPermissionException.class) | 
|     public AjaxResult handleNotPermissionException(NotPermissionException e, HttpServletRequest request) { | 
|         String requestURI = request.getRequestURI(); | 
|         log.error("请求地址'{}',权限码校验失败'{}'", requestURI, e.getMessage()); | 
|         return AjaxResult.error(HttpStatus.FORBIDDEN, "没有访问权限,请联系管理员授权"); | 
|     } | 
|      | 
|     /** | 
|      * 角色权限异常 | 
|      */ | 
|     @ExceptionHandler(NotRoleException.class) | 
|     public AjaxResult handleNotRoleException(NotRoleException e, HttpServletRequest request) { | 
|         String requestURI = request.getRequestURI(); | 
|         log.error("请求地址'{}',角色权限校验失败'{}'", requestURI, e.getMessage()); | 
|         return AjaxResult.error(HttpStatus.FORBIDDEN, "没有访问权限,请联系管理员授权"); | 
|     } | 
|      | 
|     /** | 
|      * 没有登录异常 | 
|      * @param e | 
|      * @param request | 
|      * @return | 
|      */ | 
|     @ExceptionHandler(NotLoginException.class) | 
|     public AjaxResult notLoginException(NotLoginException e, HttpServletRequest request) { | 
|         String requestURI = request.getRequestURI(); | 
|         log.error("请求地址'{}',登录校验失败'{}'", requestURI, e.getMessage()); | 
|         return AjaxResult.error(HttpStatus.UNAUTHORIZED, e.getMessage()); | 
|     } | 
|      | 
|     /** | 
|      * 请求方式不支持 | 
|      */ | 
|     @ExceptionHandler(HttpRequestMethodNotSupportedException.class) | 
|     public AjaxResult handleHttpRequestMethodNotSupported(HttpRequestMethodNotSupportedException e, | 
|                                                           HttpServletRequest request) { | 
|         String requestURI = request.getRequestURI(); | 
|         log.error("请求地址'{}',不支持'{}'请求", requestURI, e.getMethod()); | 
|         return AjaxResult.error(e.getMessage()); | 
|     } | 
|      | 
|     /** | 
|      * 业务异常 | 
|      */ | 
|     @ExceptionHandler(ServiceException.class) | 
|     public AjaxResult handleServiceException(ServiceException e, HttpServletRequest request) { | 
|         log.error(e.getMessage(), e); | 
|         Integer code = e.getCode(); | 
|         return StringUtils.isNotNull(code) ? AjaxResult.error(code, e.getMessage()) : AjaxResult.error(e.getMessage()); | 
|     } | 
|      | 
|     /** | 
|      * 拦截未知的运行时异常 | 
|      */ | 
|     @ExceptionHandler(RuntimeException.class) | 
|     public AjaxResult handleRuntimeException(RuntimeException e, HttpServletRequest request) { | 
|         String requestURI = request.getRequestURI(); | 
|         log.error("请求地址'{}',发生未知异常.", requestURI, e); | 
|         return AjaxResult.error(e.getMessage()); | 
|     } | 
|      | 
|     /** | 
|      * 系统异常 | 
|      */ | 
|     @ExceptionHandler(Exception.class) | 
|     public AjaxResult handleException(Exception e, HttpServletRequest request) { | 
|         String requestURI = request.getRequestURI(); | 
|         log.error("请求地址'{}',发生系统异常.", requestURI, e); | 
|         return AjaxResult.error(e.getMessage()); | 
|     } | 
|      | 
|     /** | 
|      * 自定义验证异常 | 
|      */ | 
|     @ExceptionHandler(BindException.class) | 
|     public AjaxResult handleBindException(BindException e) { | 
|         log.error(e.getMessage(), e); | 
|         String message = e.getAllErrors().get(0).getDefaultMessage(); | 
|         return AjaxResult.error(message); | 
|     } | 
|      | 
|     /** | 
|      * 自定义验证异常 | 
|      */ | 
|     @ExceptionHandler(MethodArgumentNotValidException.class) | 
|     public Object handleMethodArgumentNotValidException(MethodArgumentNotValidException e) { | 
|         log.error(e.getMessage(), e); | 
|         String message = e.getBindingResult().getFieldError().getDefaultMessage(); | 
|         return AjaxResult.error(message); | 
|     } | 
|      | 
|     /** | 
|      * 内部认证异常 | 
|      */ | 
|     @ExceptionHandler(InnerAuthException.class) | 
|     public AjaxResult handleInnerAuthException(InnerAuthException e) { | 
|         return AjaxResult.error(e.getMessage()); | 
|     } | 
|      | 
|     /** | 
|      * 演示模式异常 | 
|      */ | 
|     @ExceptionHandler(DemoModeException.class) | 
|     public AjaxResult handleDemoModeException(DemoModeException e) { | 
|         return AjaxResult.error("演示模式,不允许操作"); | 
|     } | 
|      | 
|     @ExceptionHandler(MaxUploadSizeExceededException.class) | 
|     public AjaxResult fileUpLoad(MaxUploadSizeExceededException e) { | 
|         log.error("上传文件异常 => : {}", e.getMessage()); | 
|         return AjaxResult.error("文件识别大小超出限制,允许的大小在" + maxFileSize); | 
|     } | 
|      | 
|     /** | 
|      * 学生端单点登录-异常信息 | 
|      */ | 
|     @ExceptionHandler(UserAppletException.class) | 
|     public AjaxResult<String> studyLoginExceptionHandler(UserAppletException e) { | 
|         return AjaxResult.error(e.getCode(), e.getMessage()); | 
|     } | 
| } |