From e26b2f48c63d8b6a7757e1e8c4f04e006ccfbfe9 Mon Sep 17 00:00:00 2001
From: skyouc <creaycat@gmail.com>
Date: 星期四, 25 十二月 2025 11:19:07 +0800
Subject: [PATCH] 修改异常抛出返回信息
---
src/main/java/com/zy/common/config/CoolExceptionHandler.java | 51 ++++++++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 48 insertions(+), 3 deletions(-)
diff --git a/src/main/java/com/zy/common/config/CoolExceptionHandler.java b/src/main/java/com/zy/common/config/CoolExceptionHandler.java
index b3968a3..a821d79 100644
--- a/src/main/java/com/zy/common/config/CoolExceptionHandler.java
+++ b/src/main/java/com/zy/common/config/CoolExceptionHandler.java
@@ -6,6 +6,9 @@
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;
import org.springframework.web.method.HandlerMethod;
+import javax.servlet.http.HttpServletRequest;
+import java.util.HashMap;
+import java.util.Map;
/**
* Created by vincent on 2019-06-09
@@ -14,18 +17,35 @@
public class CoolExceptionHandler {
@ExceptionHandler(Exception.class)
- public R handlerException(HandlerMethod handler, Exception e) {
+ public Object handlerException(HandlerMethod handler, Exception e, HttpServletRequest request) {
e.printStackTrace();
+ if (useAlt(request)) {
+ return altError("500", "鏈嶅姟鍣ㄥ唴閮ㄩ敊璇�");
+ }
return R.error();
}
@ExceptionHandler(HttpRequestMethodNotSupportedException.class)
- public R handleHttpRequestMethodNotSupportedException(HttpRequestMethodNotSupportedException e) {
+ public Object handleHttpRequestMethodNotSupportedException(HttpRequestMethodNotSupportedException e,
+ HttpServletRequest request) {
+ if (useAlt(request)) {
+ return altError("405", "HTTP鏂规硶涓嶆敮鎸�");
+ }
return R.error();
}
@ExceptionHandler(CoolException.class)
- public R handleRRException(CoolException e) {
+ public Object handleRRException(CoolException e, HttpServletRequest request) {
+ if (useAlt(request)) {
+ String[] split = e.getMessage().split("-");
+ String code = null;
+ String msg = e.getMessage();
+ if (split.length == 2 && String.valueOf(split[0]).length() < 3) {
+ code = split[0];
+ msg = split[1];
+ }
+ return altError(code, msg);
+ }
String[] split = e.getMessage().split("-");
if (split.length == 2) {
if (String.valueOf(split[0]).length() < 3) {
@@ -35,4 +55,29 @@
return R.error(e.getMessage());
}
+ private boolean useAlt(HttpServletRequest request) {
+ if (null == request) {
+ return false;
+ }
+ String header = request.getHeader("X-Response-Format");
+ if ("alt".equalsIgnoreCase(header)) {
+ return true;
+ }
+ String param = request.getParameter("responseFormat");
+ return "alt".equalsIgnoreCase(param);
+ }
+
+ private Map<String, Object> altError(String code, String message) {
+ Map<String, Object> map = new HashMap<>();
+ map.put("success", false);
+ if (null != code) {
+ map.put("code", code);
+ } else {
+ map.put("code", "200");
+ }
+ map.put("message", "澶辫触");
+ map.put("returnMessage", message);
+ map.put("timestamp", System.currentTimeMillis());
+ return map;
+ }
}
--
Gitblit v1.9.1