您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關Java項目中怎么處理異常,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
異常處理是一個系統最重要的環節,當一個項目變得很大的時候,異常處理和日志系統能讓你快速定位到問題。對于用戶或者接口調用者而言,優雅的異常處理可以讓調用者快速知道問題所在。本文將介紹如何優雅地處理異常。
我們希望所有的錯誤都以Json的方式返回給客戶,因此拿出上次寫的通用返回體,新建一個類CommonResult記錄返回體。
@Data @AllArgsConstructor @NoArgsConstructor public class CommonResult { private int code; private String message; private Object data; }
新建一個枚舉類ResponseCode集成code和message。
public enum ResponseCode { // 系統模塊 SUCCESS(0, "操作成功"), ERROR(1, "操作失敗"), SERVER_ERROR(500, "服務器異常"), // 通用模塊 1xxxx ILLEGAL_ARGUMENT(10000, "參數不合法"), REPETITIVE_OPERATION(10001, "請勿重復操作"), ACCESS_LIMIT(10002, "請求太頻繁, 請稍后再試"), MAIL_SEND_SUCCESS(10003, "郵件發送成功"), // 用戶模塊 2xxxx NEED_LOGIN(20001, "登錄失效"), USERNAME_OR_PASSWORD_EMPTY(20002, "用戶名或密碼不能為空"), USERNAME_OR_PASSWORD_WRONG(20003, "用戶名或密碼錯誤"), USER_NOT_EXISTS(20004, "用戶不存在"), WRONG_PASSWORD(20005, "密碼錯誤"), ; ResponseCode(Integer code, String msg) { this.code = code; this.msg = msg; } private Integer code; private String msg; public Integer getCode() { return code; } public void setCode(Integer code) { this.code = code; } public String getMsg() { return msg; } public void setMsg(String msg) { this.msg = msg; } }
自定義一個運行時異常類,構造方法傳入異常參數即可。
public class MyException extends RuntimeException{ private String msg; public MyException(String msg) { super(msg); } }
異常處理類是整個異常處理核心,SpringBoot中提供了ControllerAdvice注解來攔截異常,使用RestControllerAdvice注解保證了返回Json格式。
如果攔截到的異常屬于MyException,則按Json格式返回錯誤結果。
@RestControllerAdvice public class ExceptionController { @ResponseStatus(HttpStatus.BAD_REQUEST) @ExceptionHandler(value = Exception.class) public CommonResult exceptionHandler(Exception e){ //如果拋出的異常屬于自定義異常,就以JSON格式返回 if (e instanceof MyException){ return new CommonResult(ResponseCode.ERROR.getCode(),ResponseCode.ERROR.getMsg(),"自定義的錯誤為:"+e.getMessage()); } //如果都不是就打印出異常的信息 return new CommonResult(ResponseCode.ERROR.getCode(),ResponseCode.ERROR.getMsg(),"錯誤的信息為:"+e.getMessage()); } }
為了看初效果,這里手動拋出一個異常來測試,新建IndexController,手動拋出異常
@RestController public class IndexController { @RequestMapping(value = "/index",method = RequestMethod.GET) public String index(){ throw new MyException("測試"); } }
查看調用結果:
有這樣一個場景,登陸注冊時用戶名和密碼有長度限制,手機號有格式限制,如果不滿足要求就無法注冊。這個功能前端可以限制,但是對于后端接口而言,也需要進行限制,萬一前端沒有限制住呢。
導入兩個校驗依賴包:
<!--校驗--> <!-- https://mvnrepository.com/artifact/javax.validation/validation-api --> <dependency> <groupId>javax.validation</groupId> <artifactId>validation-api</artifactId> <version>2.0.1.Final</version> </dependency> <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-validator --> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-validator</artifactId> <version>6.1.0.Final</version> </dependency>
編寫實體類,在每個屬性上加上校驗包的驗證參數。
@Data public class Register { @Length(max = 20,min = 4,message = "用戶名長度需要在4到20個字符之間") @NotBlank(message = "用戶名不能為空") private String username; @NotBlank(message = "手機號不能為空") @Pattern(regexp = "^1[3|4|5|8][0-9]\\d{8}$",message = "電話號碼格式不正確") private String phone; @Length(max = 20,min = 4,message = "密碼長度需要在4到20個字符之間") @NotBlank(message = "密碼不能為空") private String password; }
我們在需要使用的方法中增加@Valid注解進行校驗,比如這個post請求中我要校驗。
@PostMapping("/register") public CommonResult register(@Valid @RequestBody Register register){ //一連串注冊的業務 userService.registerUser(register); return new CommonResult(ResponseCode.SUCCESS.getCode(),ResponseCode.SUCCESS.getMsg(),""); }
@Valid在校驗失敗的情況下會報出參數不合法的異常,還是在統一的異常處理類中捕獲異常,如果是MethodArgumentNotValidException,就取出對應的message數據。
@RestControllerAdvice public class ExceptionController { @ResponseStatus(HttpStatus.BAD_REQUEST) @ExceptionHandler(value = Exception.class) public CommonResult exceptionHandler(Exception e){ //如果屬于參數校驗異常,就拋出校驗的錯誤 if (e instanceof MethodArgumentNotValidException){ MethodArgumentNotValidException methodArgumentNotValidException= (MethodArgumentNotValidException) e; return new CommonResult(ResponseCode.ERROR.getCode(),ResponseCode.ERROR.getMsg(), "校驗錯誤:"+methodArgumentNotValidException.getBindingResult().getFieldError().getDefaultMessage()); }//如果是自定義的異常,就給出具體的異常原因 else if (e instanceof MyException){ return new CommonResult(ResponseCode.ERROR.getCode(),ResponseCode.ERROR.getMsg(),"自定義的錯誤為:"+e.getMessage()); } //如果都不是就打印出異常的信息 return new CommonResult(ResponseCode.ERROR.getCode(),ResponseCode.ERROR.getMsg(),"錯誤的信息為:"+e.getMessage()); } }
接下來就可以測試校驗的功能了,通過postman訪問
如果輸入參數不滿足之前的設置,就會給出具體的錯誤信息。而不是拋出讓人無法接收的報錯:
以上就是Java項目中怎么處理異常,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。