更新
This commit is contained in:
@@ -15,48 +15,47 @@ import java.util.Map;
|
||||
* Spring Boot 自定义异常处理
|
||||
* 所有的异常都派生自 Exception, 如果我们定义了某个异常的处理 Handler, Spring Boot 会调用用对应的异常 Handler, 否则会调用 Exception Handler.
|
||||
* 有一个前提是在 application.yml 中定义两个属性, 让 springboot 在没有找到 url 的处理器触发异常; 让 springboot 不要自作多情加 /error 这个 map
|
||||
* mvc:
|
||||
* throw-exception-if-no-handler-found: true
|
||||
* web:
|
||||
* resources:
|
||||
* add-mappings: false
|
||||
* mvc:
|
||||
* throw-exception-if-no-handler-found: true
|
||||
* web:
|
||||
* resources:
|
||||
* add-mappings: false
|
||||
* 只有如此, springboot 才会触发异常。
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
@ControllerAdvice
|
||||
public class ErrorController {
|
||||
|
||||
@ExceptionHandler(Exception.class)
|
||||
@ResponseBody
|
||||
public ResponseEntity error(Exception ex) {
|
||||
System.out.println("ErrorController.error Exception");
|
||||
ex.printStackTrace();
|
||||
Map<String, Object> map = new HashMap<>();
|
||||
map.put("Exception", ex.getClass().getName());
|
||||
map.put("message", ex.getMessage());
|
||||
map.put("localizedMessage", ex.getLocalizedMessage());
|
||||
map.put("toString", ex.toString());
|
||||
@ExceptionHandler(Exception.class)
|
||||
@ResponseBody
|
||||
public ResponseEntity error(Exception ex) {
|
||||
System.out.println("ErrorController.error Exception");
|
||||
ex.printStackTrace();
|
||||
Map<String, Object> map = new HashMap<>();
|
||||
map.put("Exception", ex.getClass().getName());
|
||||
map.put("message", ex.getMessage());
|
||||
map.put("localizedMessage", ex.getLocalizedMessage());
|
||||
map.put("toString", ex.toString());
|
||||
|
||||
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(R.failed(map, "发生异常 "+ex.getMessage()));
|
||||
}
|
||||
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(R.failed(map, "发生异常 " + ex.getMessage()));
|
||||
}
|
||||
|
||||
|
||||
@ExceptionHandler(value = {NoHandlerFoundException.class})
|
||||
@ResponseBody
|
||||
public ResponseEntity error(NoHandlerFoundException ex) {
|
||||
@ExceptionHandler(value = {NoHandlerFoundException.class})
|
||||
@ResponseBody
|
||||
public ResponseEntity error(NoHandlerFoundException ex) {
|
||||
//System.out.println("ErrorController.error NoHandlerFoundException");
|
||||
//ex.printStackTrace();
|
||||
// //ex.getRawStatusCode()
|
||||
Map<String, Object> map = new HashMap<>();
|
||||
map.put("Exception", ex.getClass().getName());
|
||||
map.put("message", ex.getMessage());
|
||||
map.put("localizedMessage", ex.getLocalizedMessage());
|
||||
map.put("requestURL", ex.getRequestURL());
|
||||
map.put("httpMethod", ex.getHttpMethod());
|
||||
Map<String, Object> map = new HashMap<>();
|
||||
map.put("Exception", ex.getClass().getName());
|
||||
map.put("message", ex.getMessage());
|
||||
map.put("localizedMessage", ex.getLocalizedMessage());
|
||||
map.put("requestURL", ex.getRequestURL());
|
||||
map.put("httpMethod", ex.getHttpMethod());
|
||||
// map.put("cause", ex.getCause().toString());
|
||||
map.put("toString", ex.toString());
|
||||
map.put("toString", ex.toString());
|
||||
// map.put("comments", "单独的 ExceptionHandler, 系统管理捕获的全局异常 NoHandlerFoundException");
|
||||
// //return map;
|
||||
// //ResponseEntity<Map<String,Object>> r = new ResponseEntity<Map<String,Object>>(map, HttpStatus.INTERNAL_SERVER_ERROR);
|
||||
@@ -64,8 +63,8 @@ ex.printStackTrace();
|
||||
// //return r;
|
||||
// return ResponseEntity.status(HttpStatus.NOT_FOUND).body(map);
|
||||
|
||||
return ResponseEntity.status(HttpStatus.NOT_FOUND).body(R.failed(map, "没有找到"));
|
||||
}
|
||||
return ResponseEntity.status(HttpStatus.NOT_FOUND).body(R.failed(map, "没有找到"));
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
package digital.laboratory.platform.entrustment.controller;
|
||||
|
||||
import digital.laboratory.platform.common.core.exception.ValidateCodeException;
|
||||
import digital.laboratory.platform.common.core.util.R;
|
||||
import digital.laboratory.platform.entrustment.entity.EntrustmentIdentificationMaterial;
|
||||
import digital.laboratory.platform.entrustment.service.AcceptService;
|
||||
@@ -25,7 +26,13 @@ public class AcceptController {
|
||||
@PutMapping("/alertMaterialAcceptNo")
|
||||
@PreAuthorize("@pms.hasPermission('EntrustmentAccept')")
|
||||
public R alertMaterialAcceptNo(@RequestBody EntrustmentIdentificationMaterial material) {
|
||||
Boolean success = acceptService.alertMaterialAcceptNo(material);
|
||||
Boolean success = null;
|
||||
try {
|
||||
success = acceptService.alertMaterialAcceptNo(material);
|
||||
} catch (ValidateCodeException e) {
|
||||
e.printStackTrace();
|
||||
return R.failed(e.getMessage());
|
||||
}
|
||||
return R.ok(success);
|
||||
}
|
||||
|
||||
|
||||
@@ -49,7 +49,7 @@ public class AcceptServiceImpl implements AcceptService {
|
||||
* ^ 和 $:表示字符串的开始和结束
|
||||
*/
|
||||
String regex = "^\\d+-\\d+-\\d+$";
|
||||
if (Pattern.matches(regex, materialAcceptNo)) {
|
||||
if (!Pattern.matches(regex, materialAcceptNo)) {
|
||||
throw new ValidateCodeException(String.format("%s 不符合检材受理编号的规则!", materialAcceptNo));
|
||||
}
|
||||
// 校验当前修改的检材受理编号对应的委托的受理编号存不存在, 委托的受理编号是检材受理编号截取最后一个横杠的内容
|
||||
|
||||
Reference in New Issue
Block a user