您的位置:

java自定义异常信息日志输出(java 输出日志文件)

本文目录一览:

Java用户自定义异常处理

一、第一种定义方式,继承Exception类

public class MyFirstException extends Exception {

public MyFirstException() {

super();

}

public MyFirstException(String msg) {

super(msg);

}

public MyFirstException(String msg, Throwable cause) {

super(msg, cause);

}

public MyFirstException(Throwable cause) {

super(cause);

}

//自定义异常类的主要作用是区分异常发生的位置,当用户遇到异常时,

//根据异常名就可以知道哪里有异常,根据异常提示信息进行修改。

}

二、 第二种定义方式:继承Throwable 类

public class MySecondException extends Throwable {

public MySecondException() {

super();

}

public MySecondException(String msg) {

super(msg);

}

public MySecondException(String msg, Throwable cause) {

super(msg, cause);

}

public MySecondException(Throwable cause) {

super(cause);

}

}

三、测试

/**

* 自定义异常类的使用

* @author new

*

*/

public class TestMyException {

public static void firstException() throws MyFirstException{

throw new MyFirstException("\"firstException()\" method occurs an exception!");

}

public static void secondException() throws MySecondException{

throw new MySecondException("\"secondException()\" method occurs an exception!");

}

public static void main(String[] args) {

try {

TestMyException.firstException();

TestMyException.secondException();

} catch (MyFirstException e1){

System.out.println("Exception: " + e1.getMessage());

e1.printStackTrace();

} catch (MySecondException e2){

System.out.println("Exception: " + e2.getMessage());

e2.printStackTrace();

}

//当一个try块后面跟着多个catch块时,如果发生的异常匹配第一个catch块的参数,便将异常处理权利交给第一个catch块。

//如果发生的异常与第一个catch块不匹配,便看是否与第二个catch块匹配,依次下去,如果到最后依然无法匹配该异常,

//便需要在方法声明中添加一条throw语句,将该异常抛出。

//因此,在有多个catch块,而且每次处理的异常类型具有继承关系时,应该首先catch子类异常,再catch父类异常。

//比如,如果MySecondException继承MyFirstException,那么最好将catch (MySecondException e2)放在前面,

//把catch (MyFirstException e1)放在后面。

}

tomcat7怎么输出java异常日志

1.找到tomcat安装目录下的bin目录。

2.修改bin目录下面的catalina.bat文件,对照这个文件,将最后一部分修改成下面这样。

rem Execute Java with the applicable properties

if not "%JPDA%" == "" goto doJpda

if not "%SECURITY_POLICY_FILE%" == "" goto doSecurity

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS% %ACTION% %CATALINA_BASE%\logs\catalina.out

goto end

:doSecurity

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Djava.security.manager -Djava.security.policy=="%SECURITY_POLICY_FILE%" -Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS% %ACTION% %CATALINA_BASE%\logs\catalina.out

goto end

:doJpda

if not "%SECURITY_POLICY_FILE%" == "" goto doSecurityJpda

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %JPDA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS% %ACTION% %CATALINA_BASE%\logs\catalina.out

goto end

:doSecurityJpda

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %JPDA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Djava.security.manager -Djava.security.policy=="%SECURITY_POLICY_FILE%" -Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS% %ACTION% %CATALINA_BASE%\logs\catalina.out

goto end

:end

3.将startup.bat中倒数第二行 call "%EXECUTABLE%" start %CMD_LINE_ARGS%?? 改为? call "%EXECUTABLE%" run %CMD_LINE_ARGS%

注:以上加粗的是指定输出路径。路径前面的“ ”代表的是输出是对当前文件的内容进行覆盖,也就是如果自己指定的catalina.out文件中有内容,将会被覆盖。如果使用“ ”, 则不会覆盖,而是在catalina.out文件尾部追加信息。

java 我想把一个服务里面的所有异常信息全部记录在logger里怎么配置

用log4j

配置文件:

?xml version="1.0" encoding="UTF-8"?

!DOCTYPE log4j:configuration PUBLIC "-//log4j/log4j Configuration//EN" "log4j.dtd"

 

log4j:configuration xmlns:log4j=""

 

    appender name="RollingAppender" class="org.apache.log4j.DailyRollingFileAppender"

       param name="File" value="logs/app.log" /

       param name="Encoding" value="UTF-8" /

       param name="DatePattern" value="'.'yyyy-MM-dd" /

       layout class="org.apache.log4j.PatternLayout"

          param name="ConversionPattern" value="[%p] %d %c %M - %m%n"/          

       /layout

    /appender

 

    root

        priority value="DEBUG"/

        appender-ref ref="RollingAppender" /

    /root

     

/log4j:configuration

运用

先实例化

运用

java自定义异常处理类

[java] view plain copy print?

/*下面做了归纳总结,欢迎批评指正*/

/*自定义异常*/

class ChushulingException extends Exception

{

public ChushulingException(String msg)

{

super(msg);

}

}

class ChushufuException extends Exception

{

public ChushufuException(String msg)

{

super(msg);

}

}

/*自定义异常 End*/

class Numbertest

{

public int shang(int x,int y) throws ChushulingException,ChushufuException

{

if(y0)

{

throw new ChushufuException("您输入的是"+y+",规定除数不能为负数!");//抛出异常

}

if(y==0)

{

throw new ChushulingException("您输入的是"+y+",除数不能为0!");

}

int m=x/y;

return m;

}

}

class Rt001

{

public static void main(String[]args)

{

Numbertest n=new Numbertest();

//捕获异常

try

{

System.out.println("商="+n.shang(1,-3));

}

catch(ChushulingException yc)

{

System.out.println(yc.getMessage());

yc.printStackTrace();

}

catch(ChushufuException yx)

{

System.out.println(yx.getMessage());

yx.printStackTrace();

}

catch(Exception y)

{

System.out.println(y.getMessage());

y.printStackTrace();

}

finally{ System.out.println("finally!");} ////finally不管发没发生异常都会被执行

}

}

/*

[总结]

1.自定义异常:

class 异常类名 extends Exception

{

public 异常类名(String msg)

{

super(msg);

}

}

2.标识可能抛出的异常:

throws 异常类名1,异常类名2

3.捕获异常:

try{}

catch(异常类名 y){}

catch(异常类名 y){}

4.方法解释

getMessage() //输出异常的信息

printStackTrace() //输出导致异常更为详细的信息

*/

为什么我在java中自定义的异常,运行时什么也没有输出??我打算想输出那个throw new MyException中的a的

e.printStackTrace();只会输出异常的调用栈信息,要输出a你要用System.out.println(e.getMessage());

java输出为:这是我自定义的异常类 MyException: 这是我自定义的异常类。我并没有输出MyException啊,

Exception的toString方法描述如下:

public String toString()

返回此 throwable 的简短描述。结果是以下字符串的串联:

此对象的类的 name + ": "(冒号和一个空格)+ 调用此对象 getLocalizedMessage()

方法的结果

如果 getLocalizedMessage 返回 null,则只返回类名称,此处 getLocalizedMessage返回时你定义的字符串,不为空。