良好的异常展现界面<500.jsp>
来源:互联网 发布:安卓新闻推荐 知乎 编辑:程序博客网 时间:2024/06/01 22:09
Web编程中,时常会出现后台报错的现象;原始界面,通常是这样展现异常的:
那么,如何才能自定义一个更加良好的界面,人性化,用户体验好的界面,就值得探索;本Demo实现的界面图是这样的:
以下是代码轰炸
1.web.xml配置
<error-page> <error-code>500</error-code> <location>/jsp/error/500.jsp</location> </error-page>
2.500.jsp
<%response.setStatus(500);// 获取异常类Throwable ex = Exceptions.getThrowable(request);// 编译错误信息StringBuilder sb = new StringBuilder("错误信息:\n");if (ex != null) { sb.append(Exceptions.getStackTraceAsString(ex));} else { sb.append("未知错误.\n\n");}// 如果是异步请求,则直接返回信息if (Servlets.isAjaxRequest(request)) { out.print(sb);}// 输出异常信息页面else {%><%@page import="com.util.Servlets"%><%@page import="com.util.Exceptions"%><%@page import="com.util.StringUtil"%><%@page contentType="text/html;charset=UTF-8" isErrorPage="true"%><!DOCTYPE html><html><head> <title>500 - 系统内部错误</title> <script src="${pageContext.request.contextPath}/js/jquery.js"></script> <!-- bootstrap需要引入的js和css文件 --> <link href="${pageContext.request.contextPath}/bootstrap/css/bootstrap.min.css" rel="stylesheet"> <link href="${pageContext.request.contextPath}/bootstrap/css/bootstrap-theme.css" rel="stylesheet"> <script src="${pageContext.request.contextPath}/bootstrap/js/bootstrap.js"></script> <script language="javascript">if(typeof jQuery == 'undefined'){ window.alert("没有jquery");}</script> <script type="text/javascript"> function change(value){ if(value == '1'){ $(".errorMessage").css("display", "none"); $(".errorMessage2").css("display", "block"); }else{ $(".errorMessage").css("display", "block"); $(".errorMessage2").css("display", "none"); } }; </script></head><body> <div class="container-fluid"> <div class="page-header"><h1>系统内部错误.</h1></div> <div class="errorMessage"> 错误信息:<%=ex==null?"未知错误.":StringUtil.toHtml(ex.getMessage())%> <br/> <br/> 请点击“查看详细信息”按钮,将详细错误信息发送给系统管理员,谢谢!<br/> <br/> <a href="javascript:" onclick="history.go(-1);" class="btn">返回上一页</a> <a href="javascript:" onclick="change('1');" class="btn">查看详细信息</a> </div> <div class="errorMessage2" style="display: none;"> <%=StringUtil.toHtml(sb.toString())%> <br/> <a href="javascript:" onclick="history.go(-1);" class="btn">返回上一页</a> <a href="javascript:" onclick="change('2');" class="btn">隐藏详细信息</a> <br/> <br/> </div> </div></body></html><%} out = pageContext.pushBody();%>
3.功能类,如Exceptions, StringUtil, Servlets
Exceptions.java
import java.io.PrintWriter;import java.io.StringWriter;import javax.servlet.http.HttpServletRequest;/** * 关于异常的工具类. */public class Exceptions { /** * 将CheckedException转换为UncheckedException. */ public static RuntimeException unchecked(Exception e) { if (e instanceof RuntimeException) { return (RuntimeException) e; } else { return new RuntimeException(e); } } /** * 将ErrorStack转化为String. */ public static String getStackTraceAsString(Throwable e) { if (e == null){ return ""; } StringWriter stringWriter = new StringWriter(); e.printStackTrace(new PrintWriter(stringWriter)); return stringWriter.toString(); } /** * 判断异常是否由某些底层的异常引起. */ public static boolean isCausedBy(Exception ex, Class<? extends Exception>... causeExceptionClasses) { Throwable cause = ex.getCause(); while (cause != null) { for (Class<? extends Exception> causeClass : causeExceptionClasses) { if (causeClass.isInstance(cause)) { return true; } } cause = cause.getCause(); } return false; } /** * 在request中获取异常类 * @param request * @return */ public static Throwable getThrowable(HttpServletRequest request){ Throwable ex = null; if (request.getAttribute("exception") != null) { ex = (Throwable) request.getAttribute("exception"); } else if (request.getAttribute("javax.servlet.error.exception") != null) { ex = (Throwable) request.getAttribute("javax.servlet.error.exception"); } return ex; }}
StringUtil.java
public class StringUtil { /** * 替换为手机识别的HTML,去掉样式及属性,保留回车。 * @param txt * @return */ public static String toHtml(String txt){ if (txt == null){ return ""; } return org.apache.commons.lang3.StringUtils.replace( org.apache.commons.lang3.StringUtils.replace(StringEscapeUtils.escapeHtml4(txt), "\n", "<br/>"), "\t", " "); }}
Servlets.java
import javax.servlet.http.HttpServletRequest;public class Servlets { /** * 是否是Ajax异步请求 * @param request */ public static boolean isAjaxRequest(HttpServletRequest request){ String accept = request.getHeader("accept"); String xRequestedWith = request.getHeader("X-Requested-With"); // 如果是异步请求,则直接返回信息 return ((accept != null && accept.indexOf("application/json") != -1 ) || (xRequestedWith != null && xRequestedWith.indexOf("XMLHttpRequest") != -1)); }}
0 0
- 良好的异常展现界面<500.jsp>
- 树形结构的jsp展现
- 6.1 程序管理器的界面展现
- 树形结构的jsp展现 (2)
- 展现层与业务数据纠缠在一起,无法进行良好的解耦
- 数据的存储和界面的展现一
- 数据的存储和界面的展现二
- 浅析 android 应用界面的展现流程(一)周期函数
- 一个可以在界面顶部展现的自定义 View
- menuToolBar.jsp(基于ext和echarts的前台展现)
- 数据存储和界面展现
- 数据存储和界面展现
- 数据存储和界面展现
- jsp常见的异常
- 一个jsp的注册界面
- SSM登录的JSP界面
- 基于HTML5的WebGL实现json和echarts图表展现在同一个界面
- Winform中长时间处理时良好的交互界面呈现_多线程
- DBCP、C3P0、Proxool 、 BoneCP开源连接池的比较
- Eclipse Debug 教程
- leetcode笔记:Partition List
- linux网络命令--1--ifconfig
- BNUOJ 51003 BQG's Confusing Sequence(二进制)
- 良好的异常展现界面<500.jsp>
- HDU 5602 Black Jack(博弈dp)
- 底部RadioButton实现Fragment切换
- Handler进程之间通信
- Looper类、主线程工作线程通信
- Activity切换中Intent传递数据、对象
- 启动其他Activity并返回结果
- 任务栏 Adobe Acrobat DC / Adobe Reader 图标出错、异常、不显示(Windows下)
- Junit测试private方法