分享一个统一异常处理返回的类
import lombok.extern.slf4j.Slf4j;
import org.springframework.dao.DataAccessException;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestController;
/**
* 统一异常处理
* @version 1.0
*/
@ControllerAdvice
@RestController
@Slf4j
public class MyException {
//我的service文件后缀 例如:UserServiceImpl。根据自己的情况修改
private final static String FILE_NAME = "ServiceImpl";
/**
* Java异常
* @param e
* @return
*/
@ExceptionHandler(Exception.class)
public String exceptionHandler(Exception e){
e.printStackTrace();
// getStackTrace()返回的是通过getOurStackTrace方法获取的StackTraceElement[]数组,而这个StackTraceElement是ERROR的每一个cause by的信息。
//这里用来存日志 错误发生在哪个文件第几行
StackTraceElement[] stackTrace = e.getStackTrace();
for (StackTraceElement stackTraceElement : stackTrace) {
if (String.valueOf(stackTraceElement.getFileName()).indexOf(FILE_NAME) > 0) {
log.error("错误文件名:{},错误方法名:{},错误行数:{}", stackTraceElement.getFileName(), stackTraceElement.getMethodName(), stackTraceElement.getLineNumber());
}
}
return "service Error";
}
/**
* Sql异常
* Spring的dao为了统一处理,屏蔽了与特定技术相关的异常,例如SQLException或HibernateException,抛出的异常是与特定技术无关的org.springframework.dao.DataAccessException类的子类。
* @param e
* @return
*/
@ExceptionHandler(DataAccessException.class)
public Result sqlExceptionHandler(DataAccessException e){
e.printStackTrace();
StackTraceElement[] stackTrace = e.getStackTrace();
for (StackTraceElement stackTraceElement : stackTrace) {
if (String.valueOf(stackTraceElement.getFileName()).indexOf(FILE_NAME) > 0) {
log.error("错误文件名:{},错误方法名:{},错误行数:{}", stackTraceElement.getFileName(), stackTraceElement.getMethodName(), stackTraceElement.getLineNumber());
}
}
return "Sql Error";
}
}