ログの出力テストを行っているのですが、エラーの発生箇所情報がうまく出力できません。
[テスト内容]
1.Registration.javaの定数フィールド「PROPERTY_FILE」に存在しないプロパティファイル名を設定。
2.Htmlページからサーブレットにリクエストを送信。
3.プロパティファイルが存在しないため、NullPointerExceptionが発生する。
4.出力されたログを確認する。
ログの出力自体は問題なくできたのですが、エラー発生箇所の情報が期待通りになりません。
ログの出力内容は以下の通りです。
log
12017-05-04 10:42:47.426 WARN [プロパティファイル未存在],取得ファイル名=url2.properties 2 registration.servlet.RegistrationServlet.init(RegistrationServlet.java:46)
()の部分の情報がログを出力している箇所(logger.warn(XXX)の行番号)が出力されました。やりたいことは(Registration.java:「エラー発生箇所であるprop.load(inStream)の行番号」)を出力させたいです。
このエラー発生箇所の情報はどのように設定するのか調べてみたのですが有力な情報が見つかりませんでした。ログ出力設定にお詳しい方がいましたらご回答をいただけないでしょうか。
原因がありそうな箇所のソースコード、設定内容を以下に共有いたします。
Java
1package registration.servlet; 2 3import java.io.IOException; 4import java.io.InputStream; 5import java.io.PrintWriter; 6import java.util.Properties; 7import java.util.logging.Logger; 8 9import javax.servlet.ServletException; 10import javax.servlet.http.HttpServlet; 11import javax.servlet.http.HttpServletRequest; 12import javax.servlet.http.HttpServletResponse; 13 14import org.apache.logging.log4j.LogManager; 15 16import registration.controller.RegistrationController; 17import util.exception.UnexpectedProcessingException; 18 19public class RegistrationServlet extends HttpServlet { 20 private static final long serialVersionUID = 1L; 21 static org.apache.logging.log4j.Logger logger = LogManager.getLogger(Logger.class.getName()); 22 final static String COMMON_URL = "CommonUrl"; 23 final static String PROPERTY_FILE = "url2.properties"; 24 final Properties prop = new Properties(); 25 26 public void init() throws ServletException{ 27 28 InputStream inStream = null; 29 try { 30 inStream = RegistrationServlet.class.getClassLoader().getResourceAsStream(PROPERTY_FILE); 31 prop.load(inStream); 32 } catch (IOException e) { 33 throw new UnexpectedProcessingException("プロパティ読み込み中にエラーが発生", e); 34 } catch (NullPointerException e) { 35 logger.warn("[プロパティファイル未存在],取得ファイル名={}", PROPERTY_FILE); 36 throw new UnexpectedProcessingException("予期せぬエラーが発生しました。", e); 37 } finally { 38 try { 39 if (inStream != null) { 40 inStream.close(); 41 } 42 } catch (IOException e) { 43 System.out.println("予期せぬエラーが発生しました。"); 44 e.printStackTrace(); 45 } 46 } 47 } 48 49 protected void doGet(HttpServletRequest request, HttpServletResponse response) 50 throws ServletException, IOException { 51 52 // パラメータを取得する 53 String process_code = request.getParameter("process_name"); 54 55 // コントローラを呼び出す 56 RegistrationController rc = new RegistrationController(); 57 rc.invoke(process_code); 58 } 59 60 protected void doPost(HttpServletRequest request, HttpServletResponse response) 61 throws ServletException, IOException { 62 63 } 64}
xml
1log4j2.xml 2 3<?xml version="1.0" encoding="UTF-8"?> 4<!DOCTYPE configuration> 5 6<configuration status="OFF"> 7 8<Properties> 9 <Property name="error_daily_log">logs/app_error_%d{yyyy-MM-dd HH:mm:ss.SSS}</Property> 10</Properties> 11 <Appenders> 12 <Console name="Console" target="SYSTEM_OUT"> 13 <PatternLayout pattern="%d{DEFAULT} | [%t] | %-5level | %c{36} | %msg%n"/> 14 </Console> 15 <File name="File" fileName="logs/normal_app.log"> 16 <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} | [%t] | %-5level | %c{36} | %msg%n"/> 17 </File> 18 <RollingFile name="RollingFile" fileName="logs/app.log" filePattern="logs/app_%date{yyyyMMddHHmmss}.log"> 19 <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %msg%n %C.%M(%F:%L)"/> 20 <Policies> 21 <TimeBasedTriggeringPolicy /> 22 </Policies> 23 </RollingFile> 24 </Appenders> 25 <Loggers> 26 <Root level="trace"> 27 <AppenderRef ref="File" /> 28 <AppenderRef ref="RollingFile" /> 29 </Root> 30 <Logger name="registration.servlet" level="debug" additivity="false"> 31 <AppenderRef ref="Console"/> 32 <AppenderRef ref="RollingFile" /> 33 </Logger> 34 </Loggers> 35</configuration>
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/05/06 01:55