import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;

import org.junit.Test;

/**
 *
 * Description: 异常信息打印(controller继承此类即可调用)
 *
 * @author: Byron Wang
 * @version: V1.0
 */
public class CommonController {

    /**
     * Description:获取子类调用处方法名字
     * @return 调用处方法名
     */
    public String getCurMethodName() {
        // 获取调用处方法的名称
        return Thread.currentThread().getStackTrace()[2].getMethodName();
    }

    public static final int ENGLISH = 0;
    public static final int CHINESE = 1;

    private static final int MSG_NUM = 5;
    private static final int NOTICE_INDEX = 0;
    private static final int HAPPEN_INDEX = 1;
    private static final int CATCH_INDEX = 2;
    private static final int MSGE_INDEX = 3;
    private static final int DATETIME_INDEX = 4;

    /**
     * Description: 获取异常日志信息(本方法不适用于单元测试中)
     *
     * @param exception
     * @param lang
     * @return
     */
    public static String getExceptionLogMsg(Exception exception, int lang) {
        String[] header = { "DEBUG MESSAGE:::", "exception happen: [",
                "exception catch : [", "\tmessage: [", "datetime: ",
                "异 常 提 示 信 息:::", "异常发生: [",
                "异常捕获: [", "\t异常信息: [", "日期时间: " };
        String lineTail = "]\n\t\t";
        int baseindex = lang * MSG_NUM;
        StackTraceElement[] stes = exception.getStackTrace();
        StackTraceElement happenTrace = stes[0];
        StackTraceElement catchTrace = stes[stes.length - 1];
        // 获取异常信息,若为空则返回异常名称
        String message = exception.getMessage();
        if (message == null || message.trim().length() == 0
                || "null".equalsIgnoreCase(message)) {
            message = exception.getClass().getName();
        }

        StringBuilder builder = new StringBuilder(header[baseindex + NOTICE_INDEX]);
        String nowStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
        builder.append(header[baseindex + DATETIME_INDEX]).append(nowStr);
        builder.append(header[baseindex + MSGE_INDEX])
                .append(message).append(lineTail);
        builder.append(header[baseindex + HAPPEN_INDEX])
                .append(joinExceptionPosition(happenTrace));
        builder.append(header[baseindex + CATCH_INDEX])
                .append(joinExceptionPosition(catchTrace));
        return builder.toString();
    }

    /**
     * Description: 拼接异常位置
     *
     * @param element
     * @return
     *
     */
    private static String joinExceptionPosition(StackTraceElement element) {
        String lineTail = "]\n\t\t";
        String seprator = "..";
        StringBuilder builder = new StringBuilder();
        builder.append(element.getClassName()).append(seprator)
                .append(element.getMethodName()).append(seprator)
                .append(element.getLineNumber()).append(lineTail);
        return builder.toString();
    }

    /**
     * TEST
     *
     * @throws IOException
     */
    public static void getException() throws IOException {
        throw new IOException("解析参数出错");
    }

    public static void getException2() throws IOException {
        getException();
    }

    @Test
    public void testException() {
        try {
            getException2();
        } catch (IOException e) {
            e.printStackTrace();
            System.out.println(getExceptionLogMsg(e, CHINESE));
        }
    }

    @Test
    public void testExceptionNoMsg() {
        try {
            throw new StringIndexOutOfBoundsException();
        } catch (StringIndexOutOfBoundsException e) {
            e.printStackTrace();
            System.out.println(getExceptionLogMsg(e, CHINESE));
        }
    }

    public static void main(String[] args) {
        try {
            throw new StringIndexOutOfBoundsException();
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println(getExceptionLogMsg(e, CHINESE));
        }
        // try {
        // getException2();
        // } catch (IOException e) {
        // e.printStackTrace();
        // System.out.println(getExceptionLogMsg(e, CHINESE));
        // }
    }

}

Java异常信息处理的更多相关文章

  1. Java异常错误的面试题及答案

    1) Java中什么是Exception? 这个问题经常在第一次问有关异常的时候或者是面试菜鸟的时候问.我从来没见过面高级或者资深工程师的 时候有人问这玩意,但是对于菜鸟,是很愿意问这个的.简单来说, ...

  2. java异常面试常见题目

    在Java核心知识的面试中,你总能碰到关于 处理Exception和Error的面试题.Exception处理是Java应用开发中一个非常重要的方面,也是编写强健而稳定的Java程序的关键,这自然使它 ...

  3. 浅谈java异常[Exception]

    学习Java的同学注意了!!! 学习过程中遇到什么问题或者想获取学习资源的话,欢迎加入Java学习交流群,群号码:589809992 我们一起学Java! 一. 异常的定义 在<java编程思想 ...

  4. 基础知识《十》java 异常捕捉 ( try catch finally ) 你真的掌握了吗?

    本文转载自  java 异常捕捉 ( try catch finally ) 你真的掌握了吗? 前言:java 中的异常处理机制你真的理解了吗?掌握了吗?catch 体里遇到 return 是怎么处理 ...

  5. Java异常体系及分类

    上图是基本的java异常体系结构. 主要分为2大类:Error和Exception 1.Error:描述了Java运行系统中的内部错误以及资源耗尽的情形.应用程序不应该抛出这种类型的对象,一般是由虚拟 ...

  6. Java异常之自定义异常

    哎呀,妈呀,又出异常了!俗话说:"代码虐我千百遍,我待代码如初恋". 小Alan最近一直在忙着工作,已经很久没有写写东西来加深自己的理解了,今天来跟大家聊聊Java异常.Java异 ...

  7. 第11章 Java异常与异常处理

    1.Java异常简介 1.什么是异常异常出现的时候代码会无法正常运行下去,会产生各种问题2.捕捉异常的作用提早发现异常,方便查找问题,并给出解决方法3.Java中的异常1.Java中所有不正常的类都是 ...

  8. java 异常

    1.java异常 2.自定义抛出 3.运行时异常,程序有问题,让使用者可以改' ' 4.return  和  throw的区别 return 符合函数要求的值    throw  有问题的时候用它结束 ...

  9. 3.Java异常进阶

    3.JAVA异常进阶 1.Run函数中抛出的异常 1.run函数不会抛出异常 2.run函数的异常会交给UncaughtExceptionhandler处理 3.默认的UncaughtExceptio ...

随机推荐

  1. 关于WIndows内核自映射方案的通俗解释

    在一次操作系统课程上听老师说了这么一个有意思的东西,windows的自映射方案居然达到了把4K的页目录的线性地址“藏”在4M页表里的效果,感觉甚是奇特,于是乎就想着说怎么去算.光会算之后仍旧不满足,我 ...

  2. [C#高级编程].NET体系结构

    本章内容: 编译和运行面向 .NET的代码 MSIL的优点 值类型和引用类型 数据类型化 理解错误处理和特性 程序集..NET基类和命名空间 本章主要介绍一些概念,内容不多. C#是专门为Micros ...

  3. [Bootstrap]7天深入Bootstrap(1)入门准备

    由于申请了一个域名,一个云主机,开始弄个人网站. 发现Bootstrap非常方便,和重要,故开始学习与分享关于Bootstrap的技术. 推个广告 个人网站:http://www.neverc.cn ...

  4. Visual Studio Code初探

    作者:Grey 本文的GIF动画均使用ScreenToGif进行录制. 摘要 微软今年发布了一款运行于 OS X,Windows 和 Linux 之上的免费跨平台编辑器: Visual Studio ...

  5. 数论 - 欧拉函数的运用 --- poj 3090 : Visible Lattice Points

    Visible Lattice Points Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5636   Accepted: ...

  6. PHP的加密解密字符串函数

    程序中经常使用的PHP加密解密字符串函数 代码如下: /********************************************************************* 函数 ...

  7. android studio...混淆打包全揭秘

    前言,当前android studio使用的版本较新,低版本的如果有差异,或者问题,欢迎拍砖! 1.修改配置文件 找到配置文件,build.gradle,修改如下.    signingConfigs ...

  8. 重新想象 Windows 8.1 Store Apps (77) - 控件增强: 文本类控件的增强, 部分控件增加了 Header 属性和 HeaderTemplate 属性, 部分控件增加了 PlaceholderText 属性

    [源码下载] 重新想象 Windows 8.1 Store Apps (77) - 控件增强: 文本类控件的增强, 部分控件增加了 Header 属性和 HeaderTemplate 属性, 部分控件 ...

  9. mysql学习笔记 第九天

    order by ,limit 和where子查询的使用 order by: order by 列名1,[列名2],[列名3]...(结果先按列1进行排序,在列1的相同的情况下,再按照列2的排序,以此 ...

  10. Bootstrap 我的学习记录3 导航条理解

    以下理论内容copy自Bootstrap中文网 (一个不错的bootstrap学习网站) 导航条 默认样式的导航条 导航条是在您的应用或网站中作为导航页头的响应式基础组件.它们在移动设备上可以折叠(并 ...