Java Exception 捕获和显示实例详解
作者:lqh 发布时间:2022-07-05 22:41:09
Java Exception 捕获和显示实例详解
在进行Java B/S架构开发时,经常有这样的场景:后端处理业务逻辑,前端负责展示,当后端处理出现异常时,如何把错误信息展示给前台呢?错误信息栈通常很多,对开发人员查找问题比较方便,但对于客户来说,打一堆的错误信息,无疑是对他们感官的一种摧残,如何捕捉最重要的信息显示到客户端呢?该信息要求简明扼要,指向出错点,且应指明异常的类型。
在很多情况下Exception的 getMessage()方法返回空的值,如果使用该方式则会在前端显示空值。我们要显示的重要信息有两个:
异常类型
出错点和出错信息
1、异常类型如何获得呢?
可以通过Exception 的getClass().getName()方法来实现。
2、出错点如何获得呢?
出错点信息一般在“Cause by:”标识开始的行。如果能抓取到该行,则可取出异常信息,一个异常栈例子如下:
Caused by: org.apache.activemq.selector.ParseException: Parse error at line 0, column 0. Encountered: <EOF>
at org.apache.activemq.selector.SelectorParser.generateParseException(SelectorParser.java:1231)
at org.apache.activemq.selector.SelectorParser.jj_consume_token(SelectorParser.java:1179)
at org.apache.activemq.selector.SelectorParser.unaryExpr(SelectorParser.java:468)
at org.apache.activemq.selector.SelectorParser.multExpr(SelectorParser.java:390)
at org.apache.activemq.selector.SelectorParser.addExpression(SelectorParser.java:359)
at org.apache.activemq.selector.SelectorParser.comparisonExpression(SelectorParser.java:211)
at org.apache.activemq.selector.SelectorParser.equalityExpression(SelectorParser.java:156)
at org.apache.activemq.selector.SelectorParser.andExpression(SelectorParser.java:135)
at org.apache.activemq.selector.SelectorParser.orExpression(SelectorParser.java:114)
at org.apache.activemq.selector.SelectorParser.JmsSelector(SelectorParser.java:106)
at org.apache.activemq.selector.SelectorParser.parse(SelectorParser.java:84)
... 63 more
由于一些原因,往往它并不出现在第一行,所以,通过取第一行的方式不能获取出错点和出错提示信息。
如果自己解析该输出,一行一行地读入,然后通过判断首字符是否是“Caused by:” 也能抓取到出错点和出错信息。
最简单的方式,还是使用正则表达式,可以比较简单地实现抓取出错点和出错信息。例如:
代码1:使用正则表达式获取出错点和出错信息
String regEx = "Caused by:(.*)";
Pattern pat = Pattern.compile(regEx);
Matcher mat = pat.matcher(content);
boolean rs = mat.find();
System.out.println("found?" + rs);
System.out.println(mat.group(1));
代码1的结果输出:
org.apache.activemq.selector.ParseException: Parse error at line 0, column 0. Encountered: <EOF>
3、异常信息的获取
虽然知道了如何找出错点,但异常信息如何获得呢?Exception.printStrackTrace()中虽然有出错点信息,但都打到控制台上去了,Exception.getStackTrace(),并不能获得出错点的提示信息。
一个应对办法就是捕获e.printStrackTrace()输出, 使用e.printStackTrace(PrintStream)方法,将异常栈信息先输出到ByteOutputStream ,然后再将ByteOutputStream 转换为字符串,就获得了异常的完整输出。代码为:
代码2:获取完整异常信息
ByteArrayOutputStream baos = new ByteArrayOutputStream();
e.printStackTrace(new PrintStream(baos));
String exception = baos.toString();
System.out.println("baos:" + exception);
完整的测试代码--异常Caused by捕获(注:该测试代码中并没有出现Caused by字样,实际应用代码比较多,没有放进测试用例中):
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.PrintStream;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class RegexpTest {
/**
* 读取文件中的内容
* @return
*/
public String readFile(){
try {
String fileName = "D:\\test2\\exception.log";
File f = new File(fileName);
FileInputStream fis = new FileInputStream(f);
int filesize = fis.available();
byte[] buffer = new byte[filesize];
fis.read(buffer);
return new String(buffer);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
/**
* 正则表达式测试
*/
public void test(){
try {
String content = readFile();
System.out.println(content);
String regEx = "Caused by:(.*)";
Pattern pat = Pattern.compile(regEx);
Matcher mat = pat.matcher(content);
boolean rs = mat.find();
System.out.println("found?" + rs);
System.out.println(mat.group(1));
// for(int i=1;i<=mat.groupCount();i++){
// System.out.println("found:" + mat.group(i));
// }
} catch (Exception e) {
e.printStackTrace();
}
}
public void test2(){
try {
FileInputStream fis = new FileInputStream("d:\\test.txt");
fis.read();
} catch (Exception e) {
e.printStackTrace();
ByteArrayOutputStream baos = new ByteArrayOutputStream();
e.printStackTrace(new PrintStream(baos));
String exception = baos.toString();
System.out.println("exception:" + exception);
}
}
public static void main(String[] args) {
RegexpTest rt = new RegexpTest();
//rt.test();
rt.test2();
}
4、获取异常类型和出错点还有一种简单的方法
获取出错点类型:
e.getCause().getClass()
获取出错点信息(出错原因):
e.getCause().getMessage()
代码示例(注:实际代码截取,不可直接运行):
@SuppressWarnings("unchecked")
@RequestMapping(value="/createSubscriber", method = RequestMethod.POST)
public @ResponseBody
WrappedResult createSubscriber(@ItemsRequestBody List<Map> list) {
LocalBrokerFacade facade = new LocalBrokerFacade(BrokerRegistry.getInstance().findFirst());
WrappedResult result = new WrappedResult();
try {
Map params = list.get(0);
String clientId = (String)params.get("clientId");
String subscriberName = (String)params.get("subscriberName");
String topicName = (String)params.get("topicName");
String selector = (String)params.get("selector");
// if("".equals(selector)){
// selector = null;
// }
facade.getBrokerAdmin().createDurableSubscriber(clientId,
subscriberName,topicName,selector);
result.setSuccessful(true);
} catch (Exception e) {
System.out.println("Exception:" + e.getCause().getClass() + "," + e.getCause().getMessage());
//log.error("createSubscriber failed.", e);
}
输出:
Exception:class org.apache.activemq.selector.ParseException,Parse error at line 0, column 0. Encountered: <EOF>
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
来源:http://blog.csdn.net/qq_35101189/article/details/67634804
猜你喜欢
- 查了下网上的一些资料,感觉比较复杂,这里,我这几使用两种很简单的办法解决了中文乱码问题。Spring版本:3.2.2.RELEASEJack
- 需求使用 spring-boot 项目开发中,项目启动时“非常”慢的。如果每次修改代码或静态资源文件后都需要重新启动项目,这是多么痛苦的事。
- 简介上一篇我们介绍了在android里如何读写本地文件。我们有一种场景,类似网页的cookie,要把用户的一些储如上一次登录、使用的痕迹等信
- 最近这款“跳一跳”很火,在段子里面看到有人才放了张画着坐标的纸在手机上,说根据
- 一、链表的介绍什么是链表链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结
- 本文实例讲述了C#采用HttpWebRequest实现保持会话上传文件到HTTP的方法,在项目开发中有一定的实用价值,具体方法如下:一、前言
- 1、super的使用:(1)super是一个关键字。(2)super和this很类似,我们对比着学习。2、先复习一下this关键字的使用。(
- 1. 什么是JWTJSON Web Token(JWT)是一个轻量级的认证规范,这个规范允许我们使用JWT在用户和服务器之间传递安全可靠的信
- 看到群里还有小伙伴说公司里还特别建了800+人的群在处理...好在很快就有了缓解措施和解决方案。同时,log4j2官方也是速度影响发布了最新
- SpringMVC实现RESTful风格RESTful中文释义为”表现层状态转换“,它不是一种标准,
- 核心考点:链表操作,临界条件检查,特殊情况处理在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针
- Mybatis-plus全局id生成策略在配置文件中加入以下代码后就不需要在实体类种的id上添加@TableId(value = “id”,
- 第1 部分 hashCode的作用Java集合中有两类,一类是List,一类是Set他们之间的区别就在于List集合中的元素师有序的,且可以
- Android之禁止ViewPager滑动实现实例当我们想在同一个Activity或者Fragment中展示多个页面时往往会用到ViewPa
- 导入thymeleaf<dependency> <groupId>org.springframework
- TubeMQ总体介绍TubeMQ是腾讯大数据在2013年开始研发的分布式消息中间件系统(MQ),专注服务大数据场景下海量数据的高性能存储和传
- 本文实例讲述了C#实现AddRange为数组添加多个元素的方法。分享给大家供大家参考。具体实现方法如下:ArrayList ab = new
- 在这篇文章中,我精选了几个比较适合 Java 编码的 IDEA 主题供小伙伴们选择。另外,我自己用的是 One Dark theme 这款。
- 使用List.contains(Object object)方法判断ArrayList是否包含一个元素对象(针对于对象的属性值相同,但对象地
- 之前调用 WebService 都是直接添加服务引用,然后调用 WebService 方法的,最近发现还可以使用 Http 请求调用 Web