1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
package cn.wisenergy.common.expection;
import cn.wisenergy.common.utils.R;
import lombok.extern.slf4j.Slf4j;
import org.apache.shiro.authz.AuthorizationException;
import org.springframework.dao.DuplicateKeyException;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;
import org.springframework.web.servlet.NoHandlerFoundException;
/**
* 统一异常处理器
* @author lut
*/
@Slf4j
@RestControllerAdvice
public class BaseExceptionHandler {
/**
* 处理自定义异常
*/
@ExceptionHandler(BaseException.class)
public R<?> handleRRException(BaseException e){
log.error(e.getMessage(), e);
return R.error(e.getCode(), e.getMsg());
}
@ExceptionHandler(NoHandlerFoundException.class)
public R<?> handlerNoFoundException(NoHandlerFoundException e) {
log.error(e.getMessage(), e);
return R.error(404, "路径不存在,请检查路径是否正确");
}
@ExceptionHandler(DuplicateKeyException.class)
public R<?> handleDuplicateKeyException(DuplicateKeyException e){
log.error(e.getMessage(), e);
return R.error("数据库中已存在该记录");
}
@ExceptionHandler(AuthorizationException.class)
public R<?> handleAuthorizationException(AuthorizationException e){
log.error(e.getMessage(), e);
return R.error("没有权限,请联系管理员授权");
}
}