设为首页 加入收藏

TOP

二、spring boot 1.5.4 异常控制(一)
2017-10-13 10:03:07 】 浏览:10115
Tags:spring boot 1.5.4 异常 控制

spring boot 已经做了统一的异常处理,下面看看如何自定义处理异常

 

1.错误码页面映射

1.1静态页面

必须配置在 resources/static/error文件夹下,以错误码命名

 

下面是404错误页面内容,当访问一个不存在的链接的时候,定位到此页

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Not Found</title>
</head>
<body>
<h1>Sorry, Not Found</h1>
<p>
    status code is 404
</p>

</body>
</html>

 显示效果

 

1.2动态模板页面(页面存放位置亦不能更改,且只有4xx和5xx这两个名称)

 

 

示例(5xx.ftl)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Error</title>
</head>
<body>
<h1>server error</h1>
<p>
<div style="color:red;font-size:large">error code: ${status}-${error}</div>
<div style="color:red;font-size:medium">error msg: ${exception!},${message!}</div>

<div>
    <div id="trace" style="color:grey;font-size:small;display: none;border: 1px solid black;padding: 10px;">${trace!}</div>
</div>
</p>
</body>
</html>

 

故意访问一个抛异常的请求(/test2/throwex)

@Controller
@RequestMapping("/test2")
public class Test2 {

    @RequestMapping("")
    public String index(){
        return "test";
    }

    @RequestMapping("/throwex")
    @ResponseBody
    public String throwex(){
        int a = 3;
        int b=0;
        return String.valueOf(a/b);
    }
}

 页面效果

如果使用ajax访问这个错误请求,则返回json表示的错误信息

演示页面(/test2 -> test.ftl)

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8" />
    <title>test</title>
    <script type="text/java script" src="/js/jquery-2.0.3.min.js"></script>
</head>
<body>
<h1>test page</h1>
<div>
    <button onclick="doAjax();">请求异常测试</button>

    <div id="msg"></div>
    <textarea id="errorMsg" style="color:red;width: 80%;height:300px"></textarea>
</div>


<script type="text/java script">
    var doAjax = function () {
        $.ajax({
            url:'/test2/throwex',
            async:true,
            type:'GET',
            data:{},
            dataType:'json',
            success:function (data) {
                $('#msg').text(data);
            },
            error: function(xhr, textStatus, errorThrown) {
//                alert(XMLHttpRequest.status);
//                alert(XMLHttpRequest.readyState);
//                alert(textStatus);
                $('#errorMsg').text(xhr.responseText);
            }
        }); 
    };
</script>
</body>
</html>

访问test页面,点击按钮,查看效果如下:

这里分别用网页浏览器和ajax访问出错的接口得到不同的结果,一个输出错误页面,一个输出错误Json,这个是由请求的接收类型决定的。

Accept:text/html -> 返回错误页面
Accept:application/json, text/java script -> 返回错误json
具体实现可查看BasicErrorController类

 

2.自定义错误码到页面的映射

2.1 静态页面映射配置(定制嵌入容器的时候控制错误码映射关系)

@Component
public class CustomizationBean implements EmbeddedServletContainerCustomizer{

    /**
     * 定制方法一:实现EmbeddedServletContainerCustomizer
     * @param container
     */
    @Override
    public void customize(ConfigurableEmbeddedServletContainer container) {
        //container.setPort(9000);
    }

    /**
     * 定制方法二:注入EmbeddedServletContainerFactor
首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇二、spring boot 1.5.4 异常控制 下一篇三、spring boot 1.5.4 web容器定..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目