Commit 46c2833f by 墨竹

feat:拦截器修改

parent a96f6e31
...@@ -49,6 +49,7 @@ import org.springframework.web.bind.annotation.RequestMethod; ...@@ -49,6 +49,7 @@ import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController; import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.validation.Valid;
import java.util.*; import java.util.*;
import java.util.stream.Collectors; import java.util.stream.Collectors;
...@@ -174,7 +175,7 @@ public class WxEnterpriseInfoController extends WebBaseController { ...@@ -174,7 +175,7 @@ public class WxEnterpriseInfoController extends WebBaseController {
*/ */
@RequestMapping(value = "welldone-login", method = RequestMethod.POST) @RequestMapping(value = "welldone-login", method = RequestMethod.POST)
@IgnoreLogin @IgnoreLogin
public HaobanResponse welldoneLogin(@RequestBody StaffLoginQO staffLoginQO, HttpServletRequest request) { public HaobanResponse welldoneLogin(@RequestBody @Valid StaffLoginQO staffLoginQO, HttpServletRequest request) {
StaffDTO staffDTO = staffApiService.selectById(staffLoginQO.getStaffId()); StaffDTO staffDTO = staffApiService.selectById(staffLoginQO.getStaffId());
if (staffDTO == null) { if (staffDTO == null) {
return resultResponse(HaoBanErrCode.ERR_6); return resultResponse(HaoBanErrCode.ERR_6);
......
package com.gic.haoban.manage.web.exception; package com.gic.haoban.manage.web.exception;
import com.gic.haoban.base.api.common.ShowFrontMessageException;
import com.gic.haoban.common.utils.HaobanResponse; import com.gic.haoban.common.utils.HaobanResponse;
import com.gic.haoban.manage.web.controller.WebBaseController; import com.gic.haoban.manage.web.controller.WebBaseController;
import com.gic.haoban.manage.web.errCode.HaoBanErrCode; import com.gic.haoban.manage.web.errCode.HaoBanErrCode;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.validation.BindException;
import org.springframework.validation.BindingResult;
import org.springframework.validation.FieldError;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.ControllerAdvice; import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler; import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.bind.annotation.ResponseBody;
...@@ -13,8 +16,6 @@ import org.springframework.web.bind.annotation.ResponseBody; ...@@ -13,8 +16,6 @@ import org.springframework.web.bind.annotation.ResponseBody;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import java.io.ByteArrayOutputStream; import java.io.ByteArrayOutputStream;
import java.io.PrintWriter; import java.io.PrintWriter;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/** /**
* Created 2018/7/24. * Created 2018/7/24.
...@@ -23,44 +24,74 @@ import java.util.regex.Pattern; ...@@ -23,44 +24,74 @@ import java.util.regex.Pattern;
*/ */
@ControllerAdvice @ControllerAdvice
public class GlobalExceptionHandler extends WebBaseController { public class GlobalExceptionHandler extends WebBaseController {
private static Logger logger = LoggerFactory.getLogger(GlobalExceptionHandler.class); private static final Logger logger = LoggerFactory.getLogger(GlobalExceptionHandler.class);
private static final Pattern pattern = Pattern.compile("(.*: )(.*)(\\n.*)"); /**
* RuntimeException 类型异常告警
*
// @ResponseBody * @param response
// @ExceptionHandler(ShowFrontMessageException.class) * @param ex
// public HaobanResponse ControllerException(HttpServletResponse response, ShowFrontMessageException ex) { * @return
// HaobanResponse res = new HaobanResponse(); */
// res.setErrorCode(HaoBanErrCode.ERR_0.getCode()); @ResponseBody
// res.setMessage(ex.getMessage()); @ExceptionHandler(RuntimeException.class)
// return res; public HaobanResponse controllerException(HttpServletResponse response, RuntimeException ex) {
// } logger.error("Exception:{}", ex.getMessage(), ex);
HaoBanErrCode errCode = HaoBanErrCode.ERR_3;
StringBuilder sb = new StringBuilder();
ByteArrayOutputStream baos = new ByteArrayOutputStream();
try (PrintWriter printWriter = new PrintWriter(baos)) {
ex.printStackTrace(printWriter);
}
try {
sb.append(baos.toString());
} catch (Exception ignored) {
}
if (sb.length() == 0) {
sb.append(ex.getMessage());
}
// 输出详细错误信息,便于调试
return resultResponse(errCode, null, sb.toString());
}
/**
* valid 异常告警
*
* @param response
* @param ex
* @return
*/
@ResponseBody
@ExceptionHandler(BindException.class)
public HaobanResponse bindException(HttpServletResponse response, BindException ex) {
logger.error("Exception:{}", ex.getMessage(), ex);
HaoBanErrCode errCode = HaoBanErrCode.ERR_5;
BindingResult bindingResult = ex.getBindingResult();
FieldError fieldError = bindingResult.getFieldError();
return resultResponse(errCode, null, fieldError.getField() + fieldError.getDefaultMessage());
}
// @ResponseBody /**
// @ExceptionHandler(RuntimeException.class) * valid 异常告警 @ReuqestBody
// public HaobanResponse ControllerException(HttpServletResponse response, RuntimeException ex) { *
// HaobanResponse res = new HaobanResponse(); * @param response
// res.setErrorCode(HaoBanErrCode.ERR_3.getCode()); * @param ex
// String message = ex.getMessage(); * @return
// if (message != null && message.indexOf(ShowFrontMessageException.class.getName()) > -1) { */
// Matcher matcher = pattern.matcher(message); @ResponseBody
// while (matcher.find()) { @ExceptionHandler(MethodArgumentNotValidException.class)
// message = (matcher.group(2)); public HaobanResponse methodArgumentNotValidException(HttpServletResponse response, MethodArgumentNotValidException ex) {
// } logger.error("Exception:{}", ex.getMessage(), ex);
// } else { HaoBanErrCode errCode = HaoBanErrCode.ERR_5;
// message = HaoBanErrCode.ERR_3.getMsg(); BindingResult bindingResult = ex.getBindingResult();
// } FieldError fieldError = bindingResult.getFieldError();
// res.setMessage(message); return resultResponse(errCode, null, fieldError.getField() + fieldError.getDefaultMessage());
// return res; }
// }
@ResponseBody @ResponseBody
@ExceptionHandler(Exception.class) @ExceptionHandler(Exception.class)
public HaobanResponse ControllerException(HttpServletResponse response, Exception ex) { public HaobanResponse globalException(HttpServletResponse response, Exception ex) {
logger.error("err:", ex.getMessage()); logger.error("Exception:{}", ex.getMessage(), ex);
ex.printStackTrace();
HaoBanErrCode errCode = HaoBanErrCode.ERR_3; HaoBanErrCode errCode = HaoBanErrCode.ERR_3;
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
ByteArrayOutputStream baos = new ByteArrayOutputStream(); ByteArrayOutputStream baos = new ByteArrayOutputStream();
...@@ -74,17 +105,9 @@ public class GlobalExceptionHandler extends WebBaseController { ...@@ -74,17 +105,9 @@ public class GlobalExceptionHandler extends WebBaseController {
if (sb.length() == 0) { if (sb.length() == 0) {
sb.append(ex.getMessage()); sb.append(ex.getMessage());
} }
// 输出详细错误信息,便于调试 // 输出详细错误信息,便于调试
// return resultResponse(errCode, null, sb.toString()); return resultResponse(errCode, null, sb.toString());
return resultResponse(HaoBanErrCode.ERR_3);
} }
@ResponseBody
@ExceptionHandler(NoLoginException.class)
public HaobanResponse ControllerException(HttpServletResponse response, NoLoginException ex) {
return resultResponse(HaoBanErrCode.ERR_4);
}
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment