用@RequestBody,@ResponseBody,不費吹灰之力就解決了JSon自動綁定。接着就發現,若是遇到RuntimeException,須要給出一個默認返回JSONspa
三種方式:日誌
1.當這個Controller中任何一個方法發生異常,必定會被這個方法攔截到。而後,輸出日誌。封裝Map並返回,頁面上獲得status爲false。就這麼簡單。code
代碼以下blog
1 @Controller 2 public class AccessController { 3 4 /** 5 * 異常頁面控制 6 * 7 * @param runtimeException 8 * @return 9 */ 10 @ExceptionHandler(RuntimeException.class) 11 public @ResponseBody 12 Map<String,Object> runtimeExceptionHandler(RuntimeException runtimeException) { 13 logger.error(runtimeException.getLocalizedMessage()); 14 15 Map model = new TreeMap(); 16 model.put("status", false); 17 return model; 18 } 19 20 }
2.返回到錯誤界面get
代碼以下it
1 @Controller 2 public class AccessController { 3 /** 4 * 異常頁面控制 5 * 6 * @param runtimeException 7 * @return 8 */ 9 @ExceptionHandler(RuntimeException.class) 10 public String runtimeExceptionHandler(RuntimeException runtimeException, 11 ModelMap modelMap) { 12 logger.error(runtimeException.getLocalizedMessage()); 13 14 modelMap.put("status", IntegralConstant.FAIL_STATUS); 15 return "exception"; 16 } 17 }
3.使用 @ControllerAdvice,不用任何的配置,只要把這個類放在項目中,Spring能掃描到的地方。就能夠實現全局異常的回調。io
代碼以下class
@ControllerAdvice public class SpringExceptionHandler{ /** * 全局處理Exception * 錯誤的狀況下返回500 * @param ex * @param req * @return */ @ExceptionHandler(value = {Exception.class}) public ResponseEntity<Object> handleOtherExceptions(final Exception ex, final WebRequest req) { TResult tResult = new TResult(); tResult.setStatus(CodeType.V_500); tResult.setErrorMessage(ex.getMessage()); return new ResponseEntity<Object>(tResult,HttpStatus.OK); } }