博客
关于我
SpringBoot全局统一异常处理(包含404错误处理)
阅读量:342 次
发布时间:2019-03-04

本文共 1768 字,大约阅读时间需要 5 分钟。

SpringBoot全局统一异常处理(包含404错误处理)

1.ControllerAdvice&&ExceptionHandler处理异常

package com.lius.controllers;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;@RestController@RequestMapping("/exception")public class testExceptionColtroller {	@RequestMapping("/nullException")	public String nullException() {		//触发空指针异常		throw new NullPointerException("空指针异常!");	}}
package com.lius.handler;import java.util.HashMap;import java.util.Map;import org.springframework.web.bind.annotation.ExceptionHandler;import org.springframework.web.bind.annotation.ResponseBody;import org.springframework.web.bind.annotation.RestControllerAdvice;@RestControllerAdvice(basePackages = "com.lius.controllers")public class handlerException {	@ExceptionHandler(NullPointerException.class)	@ResponseBody	private Map
handlerNullPointException(){ Map
map = new HashMap<>(); map.put("code", 500); map.put("message", "代码错误,空指针异常!"); return map; }}

 

2.ErrorController拦截处理404异常

package com.lius.controllers;import java.util.HashMap;import java.util.Map;import org.springframework.boot.web.servlet.error.ErrorController;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.ResponseBody;/** * 

处理404等error错误

* @author lius * */@Controllerpublic class errorController implements ErrorController { @Override public String getErrorPath() { // TODO Auto-generated method stub return "/error"; } @RequestMapping("/error") @ResponseBody public Map
handlerError(){ Map
errMap = new HashMap<>(); errMap.put("code", 404); errMap.put("message", "404页面未找到!"); return errMap; }}

 

转载地址:http://innq.baihongyu.com/

你可能感兴趣的文章
MySQL执行SQL文件出现【Unknown collation ‘utf8mb4_0900_ai_ci‘】的解决方案
查看>>
Mysql执行update by id的过程
查看>>
mysql执行计划
查看>>
MySQL执行计划 EXPLAIN参数
查看>>
MySQL执行计划【explain】,看这一篇就够啦!
查看>>
Mysql执行计划字段解释
查看>>
mysql执行计划怎么看
查看>>
MySQL执行计划解读
查看>>
mysql执行顺序与索引算法
查看>>
mysql批量update优化_Mysql中,21个写SQL的好习惯,你值得拥有呀
查看>>
mysql批量update操作时出现锁表
查看>>
MYSQL批量UPDATE的两种方式
查看>>
mysql批量修改字段名(列名)
查看>>
MySQL批量插入数据遇到错误1213的解决方法
查看>>
mysql技能梳理
查看>>
MySQL报Got an error reading communication packets错
查看>>
Mysql报错Can‘t create/write to file ‘/tmp/#sql_3a8_0.MYD‘ (Errcode: 28 - No space left on device)
查看>>
MySql报错Deadlock found when trying to get lock; try restarting transaction 的问题解决
查看>>
MySQL报错ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘
查看>>
Mysql报错Packet for query is too large问题解决
查看>>