質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
XML

XMLは仕様の1つで、マークアップ言語群を構築するために使われています。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

10000閲覧

ログにエラー発生箇所情報が出力できない。

Linkey

総合スコア77

XML

XMLは仕様の1つで、マークアップ言語群を構築するために使われています。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2017/05/04 02:01

ログの出力テストを行っているのですが、エラーの発生箇所情報がうまく出力できません。

[テスト内容]
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>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ログのWARNの行の下が例外発生の文字列ということでしょうか。
これは最終的に発した例外の情報を示しているようなので、NullPointerExceptionによるものではなく、
自分で投げたUnexpectedProcessingExceptionの例外情報となります。
なので、この行番号は実はthrow new UnexpectedProcessingException("予期せぬエラーが発生しました。", e);の行です。

catchの引数のようになっているeはException系クラス型のインスタンスであり、
その中にはスタックトレースという情報が含まれています。
このスタックトレース情報は、ThrowableクラスのgetStackTrace()メソッドで取得できます。
後は、この中から自クラス内の実行ポイント、もしくは実行したinitメソッドを含む実行ポイントを探し出せばいいのだと思います。
こんな風に…(未検証)

java

1} catch (NullPointerException e) { 2 StackTraceElement[] elements = e.getStackTrace(); 3 String name = this.getClass().getName(); 4 for (StackTraceElement ste : elements) { 5 if (ste.getClassName().equals(name)){ 6 String log = ste.toString(); //この文字列を出力すればいい 7 } 8 } 9 logger.warn("[プロパティファイル未存在],取得ファイル名={}", PROPERTY_FILE); 10 throw new UnexpectedProcessingException("予期せぬエラーが発生しました。", e); 11}

投稿2017/05/04 02:25

swordone

総合スコア20651

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Linkey

2017/05/06 01:55

ログ出力の参考にさせていただきます。ありがとうございます。
guest

0

ベストアンサー

prop.load(inStream) で発生した例外はアプリケーション内で catch してしまっているので、ハンドルされていない例外はその下の throw new UnexpectedProcessingException() となり、その行がスタックトレースとして出力されているだけで、ログ出力とは直接関係ないと思います。

ロガーは、ログに何かを出力する以上のことは何もしないので、例外が発生した行番号をログに出したいなら、logger.warn("[プロパティファイル未存在],取得ファイル名={}", PROPERTY_FILE); の所で、自力でスタックトレースを見て、行番号を出力に追加してください。

スタックトレースに単純に出力されればいいだけなら、UnexpectedProcessingException でラップするのを止めて、catch した NullPointerException をそのまま throw してもいけるかもしれません(できないかも)。

投稿2017/05/04 02:31

koko_u

総合スコア936

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問