spring boot 已经做了统一的异常处理,下面看看如何自定义处理异常
1.错误码页面映射
1.1静态页面
必须配置在 resources/static/error文件夹下,以错误码命名
下面是404错误页面内容,当访问一个不存在的链接的时候,定位到此页
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<!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)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<!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)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
@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)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
<!doctype html> <html> <head> <meta charset= "utf-8" /> <title>test</title> <script type= "text/javascript" 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/javascript" > 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,这个是由请求的接收类型决定的。
2.自定义错误码到页面的映射
2.1 静态页面映射配置(定制嵌入容器的时候控制错误码映射关系)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
@component public class customizationbean implements embeddedservletcontainercustomizer{ /** * 定制方法一:实现embeddedservletcontainercustomizer * @param container */ @override public void customize(configurableembeddedservletcontainer container) { //container.setport(9000); } /** * 定制方法二:注入embeddedservletcontainerfactory * @return */ @bean public embeddedservletcontainerfactory servletcontainer() { tomcatembeddedservletcontainerfactory factory = new tomcatembeddedservletcontainerfactory(); factory.setport( 9001 ); factory.setsessiontimeout( 10 , timeunit.minutes); //优先级高于配置在/static/error文件夹里面的404.html页面 factory.adderrorpages( new errorpage(httpstatus.not_found, "/error/403.html" )); return factory; } } |
2.2 动态页面映射配置
1
2
3
4
5
6
7
8
9
|
@component public class myerrorviewresolver implements errorviewresolver { @override public modelandview resolveerrorview(httpservletrequest request, httpstatus status, map<string, object> model) { return new modelandview( "/error/error" ,model); } } |
这个自定义viewresolver将替代默认的页面处理器defaulterrorviewresolver,上述配置将所有错误(不区分错误码)都映射到了错误页面error.ftl,进行统一管理。
新建error.ftl页面渲染错误内容
和5xx.ftl类似的配置
3.一些异常配置
#basicerrorcontroller的请求路径(你可以遇到错误后跳转的路径,该路径是一个basicerrorcontroller的请求路径,映射到它errorhtml或者error方法,由请求接受类型决定,一个返回错误页面,一个返回错误json)
#server.error.path=/error
#always include stacktrace(是否包含异常的堆栈信息,默认never,页面无法获取到${trace!}的值,可取值never,always,on_trace_param; on_trace_param意思是请求带上参数 ?trace=true)
server.error.include-stacktrace=always
4.springboot异常处理流程
controller->出错跳转->basicerrorcontroller->调用errorhtml方法->geterrorattributes(获取错误属性返回model)->丢给页面处理器errorviewresolver
所以你可以定制controller/定制errorattributes/定制errorviewresolver等,实现更加复杂的异常处理
以上这篇浅谈spring boot 1.5.4 异常控制就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。