RuoYi
4 years ago
7 changed files with 207 additions and 16 deletions
@ -0,0 +1,117 @@
@@ -0,0 +1,117 @@
|
||||
package com.ruoyi.common.security.handler; |
||||
|
||||
import org.slf4j.Logger; |
||||
import org.slf4j.LoggerFactory; |
||||
import org.springframework.security.access.AccessDeniedException; |
||||
import org.springframework.security.authentication.AccountExpiredException; |
||||
import org.springframework.security.core.userdetails.UsernameNotFoundException; |
||||
import org.springframework.validation.BindException; |
||||
import org.springframework.web.bind.MethodArgumentNotValidException; |
||||
import org.springframework.web.bind.annotation.ExceptionHandler; |
||||
import org.springframework.web.bind.annotation.RestControllerAdvice; |
||||
import org.springframework.web.servlet.NoHandlerFoundException; |
||||
import com.ruoyi.common.core.constant.HttpStatus; |
||||
import com.ruoyi.common.core.exception.BaseException; |
||||
import com.ruoyi.common.core.exception.CustomException; |
||||
import com.ruoyi.common.core.exception.DemoModeException; |
||||
import com.ruoyi.common.core.utils.StringUtils; |
||||
import com.ruoyi.common.core.web.domain.AjaxResult; |
||||
|
||||
/** |
||||
* 全局异常处理器 |
||||
* |
||||
* @author ruoyi |
||||
*/ |
||||
@RestControllerAdvice |
||||
public class GlobalExceptionHandler |
||||
{ |
||||
private static final Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class); |
||||
|
||||
/** |
||||
* 基础异常 |
||||
*/ |
||||
@ExceptionHandler(BaseException.class) |
||||
public AjaxResult baseException(BaseException e) |
||||
{ |
||||
return AjaxResult.error(e.getMessage()); |
||||
} |
||||
|
||||
/** |
||||
* 业务异常 |
||||
*/ |
||||
@ExceptionHandler(CustomException.class) |
||||
public AjaxResult businessException(CustomException e) |
||||
{ |
||||
if (StringUtils.isNull(e.getCode())) |
||||
{ |
||||
return AjaxResult.error(e.getMessage()); |
||||
} |
||||
return AjaxResult.error(e.getCode(), e.getMessage()); |
||||
} |
||||
|
||||
@ExceptionHandler(NoHandlerFoundException.class) |
||||
public AjaxResult handlerNoFoundException(Exception e) |
||||
{ |
||||
log.error(e.getMessage(), e); |
||||
return AjaxResult.error(HttpStatus.NOT_FOUND, "路径不存在,请检查路径是否正确"); |
||||
} |
||||
|
||||
@ExceptionHandler(AccessDeniedException.class) |
||||
public AjaxResult handleAuthorizationException(AccessDeniedException e) |
||||
{ |
||||
log.error(e.getMessage()); |
||||
return AjaxResult.error(HttpStatus.FORBIDDEN, "没有权限,请联系管理员授权"); |
||||
} |
||||
|
||||
@ExceptionHandler(AccountExpiredException.class) |
||||
public AjaxResult handleAccountExpiredException(AccountExpiredException e) |
||||
{ |
||||
log.error(e.getMessage(), e); |
||||
return AjaxResult.error(e.getMessage()); |
||||
} |
||||
|
||||
@ExceptionHandler(UsernameNotFoundException.class) |
||||
public AjaxResult handleUsernameNotFoundException(UsernameNotFoundException e) |
||||
{ |
||||
log.error(e.getMessage(), e); |
||||
return AjaxResult.error(e.getMessage()); |
||||
} |
||||
|
||||
@ExceptionHandler(Exception.class) |
||||
public AjaxResult handleException(Exception e) |
||||
{ |
||||
log.error(e.getMessage(), e); |
||||
return AjaxResult.error(e.getMessage()); |
||||
} |
||||
|
||||
/** |
||||
* 自定义验证异常 |
||||
*/ |
||||
@ExceptionHandler(BindException.class) |
||||
public AjaxResult validatedBindException(BindException e) |
||||
{ |
||||
log.error(e.getMessage(), e); |
||||
String message = e.getAllErrors().get(0).getDefaultMessage(); |
||||
return AjaxResult.error(message); |
||||
} |
||||
|
||||
/** |
||||
* 自定义验证异常 |
||||
*/ |
||||
@ExceptionHandler(MethodArgumentNotValidException.class) |
||||
public Object validExceptionHandler(MethodArgumentNotValidException e) |
||||
{ |
||||
log.error(e.getMessage(), e); |
||||
String message = e.getBindingResult().getFieldError().getDefaultMessage(); |
||||
return AjaxResult.error(message); |
||||
} |
||||
|
||||
/** |
||||
* 演示模式异常 |
||||
*/ |
||||
@ExceptionHandler(DemoModeException.class) |
||||
public AjaxResult demoModeException(DemoModeException e) |
||||
{ |
||||
return AjaxResult.error("演示模式,不允许操作"); |
||||
} |
||||
} |
@ -1,5 +1,6 @@
@@ -1,5 +1,6 @@
|
||||
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ |
||||
com.ruoyi.common.security.service.UserDetailsServiceImpl,\ |
||||
com.ruoyi.common.security.handler.CustomAccessDeniedHandler |
||||
com.ruoyi.common.security.handler.CustomAccessDeniedHandler,\ |
||||
com.ruoyi.common.security.handler.GlobalExceptionHandler |
||||
|
||||
|
||||
|
@ -0,0 +1,66 @@
@@ -0,0 +1,66 @@
|
||||
package com.ruoyi.gateway.handler; |
||||
|
||||
import org.springframework.cloud.gateway.support.NotFoundException; |
||||
import org.slf4j.Logger; |
||||
import org.slf4j.LoggerFactory; |
||||
import org.springframework.boot.web.reactive.error.ErrorWebExceptionHandler; |
||||
import org.springframework.context.annotation.Configuration; |
||||
import org.springframework.core.annotation.Order; |
||||
import org.springframework.core.io.buffer.DataBufferFactory; |
||||
import org.springframework.http.HttpStatus; |
||||
import org.springframework.http.MediaType; |
||||
import org.springframework.http.server.reactive.ServerHttpResponse; |
||||
import org.springframework.web.server.ResponseStatusException; |
||||
import org.springframework.web.server.ServerWebExchange; |
||||
import com.alibaba.fastjson.JSON; |
||||
import com.ruoyi.common.core.domain.R; |
||||
import reactor.core.publisher.Mono; |
||||
|
||||
/** |
||||
* 网关统一异常处理 |
||||
* |
||||
* @author ruoyi |
||||
*/ |
||||
@Order(-1) |
||||
@Configuration |
||||
public class GatewayExceptionHandler implements ErrorWebExceptionHandler |
||||
{ |
||||
private static final Logger log = LoggerFactory.getLogger(GatewayExceptionHandler.class); |
||||
|
||||
@Override |
||||
public Mono<Void> handle(ServerWebExchange exchange, Throwable ex) |
||||
{ |
||||
ServerHttpResponse response = exchange.getResponse(); |
||||
|
||||
if (exchange.getResponse().isCommitted()) |
||||
{ |
||||
return Mono.error(ex); |
||||
} |
||||
|
||||
String msg; |
||||
|
||||
if (ex instanceof NotFoundException) |
||||
{ |
||||
msg = "服务未找到"; |
||||
} |
||||
else if (ex instanceof ResponseStatusException) |
||||
{ |
||||
ResponseStatusException responseStatusException = (ResponseStatusException) ex; |
||||
msg = responseStatusException.getMessage(); |
||||
} |
||||
else |
||||
{ |
||||
msg = "内部服务器错误"; |
||||
} |
||||
|
||||
log.error("[网关异常处理]请求路径:{},异常信息:{}", exchange.getRequest().getPath(), ex.getMessage()); |
||||
|
||||
response.getHeaders().setContentType(MediaType.APPLICATION_JSON); |
||||
response.setStatusCode(HttpStatus.OK); |
||||
|
||||
return response.writeWith(Mono.fromSupplier(() -> { |
||||
DataBufferFactory bufferFactory = response.bufferFactory(); |
||||
return bufferFactory.wrap(JSON.toJSONBytes(R.fail(msg))); |
||||
})); |
||||
} |
||||
} |
Loading…
Reference in new issue