在我的应用程序中,我使用的是log4j
并且有一个my_system.log
,其中应该抛出所有消息。我遇到的问题是,当发生错误时,它也出现在server.log
中(我不希望这种情况发生)。
public String getAccessFlag (String userId, String participantCode, String roleId) {
HashMap parmMap = new HashMap();
parmMap.put("userId", userId.toUpperCase());
parmMap.put("roleId", roleId);
log.info(parmMap);
try {
getSqlMapClientOltp().queryForList("auth.getAccess", parmMap);
} catch (SQLException ex) {
log.error(ex, ex);
throw new RuntimeException (ex);
}
List result = (List)parmMap.get("Result0");
return ((String)(((HashMap) result.get(0)).get("accessVoucher"))).trim();
}
正如您所看到的,我正在捕获异常,因为我想在my_system.log
中记录它,但因为我希望执行暂停(因为错误发生)我再次抛出错误。
我相信因为我扔它,它在server.log中显示。
我该如何避免这种情况?
更新:
以下是我的追随者:
<appender name="myAppender" class="org.apache.log4j.AsyncAppender">
<appender-ref ref="myFile" />
</appender>
<appender name="myFile" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="../systems/my/log/my_system.log" />
<param name="Append" value="true" />
<param name="DatePattern" value="'.'yyyy-MM-dd" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[%d{dd/MMM/yyyy:HH:mm:ss.SSS}]~[%-5p]~[%c:%M]~[%m]%n" />
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="LevelMin" value="TRACE#com.org.common.logging.HUDLogLevel" />
<param name="LevelMax" value="FATAL" />
</filter>
</appender>
答案 0 :(得分:1)
所有未捕获的异常都将转到服务器日志。如果您不想去那里,请不要重新使用RuntimeException
。
如果要暂停方法执行,只需从方法中return
。
如果您还想在调用方法中暂停执行,则不要重新抛出未经检查的异常。声明方法是抛出已检查的异常并捕获它并将其记录在调用者中。
您可以为未捕获的异常设置自定义异常处理程序:
Thread.currentThread().setUncaughtExceptionHandler(yourExceptionHandler);
但是我建议改变代码,而不是在随机的地方放置这样的“黑客”。
相关问题:How can I configure log4j to not print the exception stactrace