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

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

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

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

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

受付中

Java Servletで"localhost_access_log.yyyy-mm-dd.txt"が生成されない

MeguroHarumi
MeguroHarumi

総合スコア0

Java

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

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

0回答

0評価

0クリップ

717閲覧

投稿2019/08/22 04:52

編集2022/01/12 10:55

前提・実現したいこと

現在サーブレットの勉強をしており、以下のJavaコードの疎通を試しています。内容としてはinitメソッドの中でログ(localhost.yyyy-mm-dd.log)を出力し、その中に「"init method is called"」という文言を出力したいです。

発生している問題・エラーメッセージ

現状はログファイル自体が生成されておらず、原因の切り分けも出来ていない状況です。

エラーメッセージなし

該当のソースコード

Java

package studyservlet; import java.io.IOException; import javax.servlet.ServletConfig; import javax.servlet.ServletContext; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * Servlet implementation class ServletLifeCycle */ @WebServlet("/ServletLifeCycle") public class ServletLifeCycle extends HttpServlet { private static final long serialVersionUID = 1L; /** * @see HttpServlet#HttpServlet() */ public ServletLifeCycle() { super(); // TODO Auto-generated constructor stub } /** * @see Servlet#init(ServletConfig) */ @Override public void init(ServletConfig config) throws ServletException { super.init(config); ServletContext application = this.getServletContext(); application.log("init method is called"); System.out.println("**** Test of Log Generation ****"); } /** * @see Servlet#destroy() */ public void destroy() { } /** * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) */ protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub response.getWriter().append("Served at: ").append(request.getContextPath()); } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub doGet(request, response); } }

試したこと

まずはservlet.xmlにロガーが登録されているか?をチェックしました。

/usr/local/src/apache-tomcat-8.5.42/conf/servlet.xml

そして登録が無かったため、<Host></Host>内に以下を追加しました。

<Context path="/TestProject" docBase="TestProject" reloadable="true" source="org.eclipse.jst.jee.server:TestProject"/> <Logger className="org.apache.catalina.logger.FileLogger" prefix="HelloLifeCyecle" suffix=".log" timestamp="true" /> </Context>

補足情報(FW/ツールのバージョンなど)

OS : CentOS release 6.9 (Final)
Eclipse:Eclipse(OXYGEN)
Tomcat : v8.5

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

m.ts10806
m.ts10806

2019/08/22 04:58

あくまでコンソールに出力されているだけに見えますが
MeguroHarumi
MeguroHarumi

2019/08/22 09:44

失礼いたしました、ご指摘ありがとうございます。質問文に誤りがありましたので、修正いたしました。
asahina1979
asahina1979

2019/08/23 00:26

localhost_access_log.yyyy-mm-dd.txt は アクセスログであってそこにアクセス以外のログを書き込むのは誤っている
MeguroHarumi
MeguroHarumi

2019/08/23 05:04

ご指摘ありがとうごいます。すみません、ログファイルの名前も違っていたようですので修正しました。自力でも調べてみますが、もしこのログを出力するための設定で見落としがちなポイントがあればご教示頂けると助かります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Java

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

servlet

Servletとは、Webページの動的な生成やデータ処理などをサーバ上で実行するために、Javaで作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。