JAVAサーブレットで、わからないことがありお伺いいたします。
名前、タイトル、メッセージが入力されていないと、エラー画面になるように設定したと思っています。
ソースが3つあり、
(1)拡張子jspのソース
ここでBBSの投稿フォームおよび投稿後のフォームの呼び出し
(2)拡張子javaのソース
フォームから入力された内容の取得および「bean」へ登録
(3)拡張子javaのソース
投稿内容の値の保持および取り出し
となっています。
(2)に
if(!isEmpty(name) && !isEmpty(subject) && !isEmpty(message) ){
// beanにフォームデータをセット
があるので下記を記述しました。
}else {ServletContext sc = getServletContext();
RequestDispatcher rd = sc.getRequestDispatcher("/error.jsp");
rd.forward(request, response); }
それでも、どれか一つを抜かして「投稿」ボタンを押しても、元の初期画面に戻ってしまいエラー画面が出ません。
記述の仕方がいけないのでしょうか。
宜しくお願い致します。
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
javax.servlet.http.HttpServlet
の親の
javax.servlet.GenericServlet
に
log(String msg)
が実装されていますので、
javax.servlet.http.HttpServlet
を継承していれば何もしないで
log("処理開始:引数hoge="+hoge);
のように使えます。
出力ファイルは…環境に環境によって違うでしょうが、
自分の場合は
Tomcat 4.1.31
で、examplesに試し用のサーブレットで試したら
[Tomcatのインストールディレクトリ]\logs
以下に
localhost_examples_log.2005-05-16.txt
というファイルで出力されていました。
ご参考までに…。
log4jについては
http://www.techscore.com/tech/Java/index.html#J2EE
を参考になさるといいとお思います。
参考URL:http://www.techscore.com/tech/Java/index.html#J2EE
No.2
- 回答日時:
ログですが、出せますよ。
サーブレットならHttpServletクラスを継承しているはずなので、
logメソッド
が実装されているはずです。
(…今手元にサーブレットのjavadocがないので「はず」で回答しています…。)
出力ファイルは…記憶があやふやですが、
Tomcatのインストールディレクトリの下にlogというディレクトリがあるので、そこに出力されたような…
それか、初期画面に表示しちゃうとか…。(^^;A
log4jというログ出力のパッケージがありますので、そちらを使ってみるのもいいかもしれません。
(log4jの使い方覚えないといけませんが…。)
とりあえずサーブレットのjavadocを調べてlogメソッドを使用するのが1番てっとり早いと思います。
No.1
- 回答日時:
(2)のisEmpty()
がどういう判断をしているか?
name、subject、messageがどうなっているか?
ですね。
name,subject,messageがStringと仮定しますが、
nullだったらtrueを返すところ、実際には""(長さ0の文字列)が入っているためfalseを返していたりしませんか?
まずは問題の切り分けですね。
デバッガを使用しているのなら、ステップ実行などを行って、
if(!isEmpty(name)&&!isEmpty(subject)&&!isEmpty(message)){
A
}else{
B
}
Aに入っているのか、Bに入っているのか?
(デバッガがなければログを出力してみる)
isEmpty()で引数の値をログに出力してみるなどして、
どこにどういう値が入ってきて、どこを通っているか?
を探ってみるといいと思います。
念のためをいうと、
name,subject,message
の値を取得したところからログなどに出した方がいいかもしれませんね。
この回答への補足
お返事ありがどうございます。(だいぶ遅れてすみません。)
ログの出し方はどうすればいいのでしょうか?
今現在、j2sdkとTomcatしかインストールしていませんが、それでも出せますでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
System.err. printlnとSystem.o...
-
1~100までの数字を表示し、か...
-
System.out.printlnの出力先
-
flush()とclose()について
-
switch分が機能しません。
-
Javascript で、0000 から 9999...
-
Tomcatが無応答となる現象が起...
-
サーブレットのログ出力先
-
JavaScriptとVBScriptに関して
-
javaにおけるCSV出力時の文字コ...
-
テキストエリアで改行する
-
Javaで改行などが出来ないのです。
-
system.out.printが出力されない
-
ダブルクォーテーション(””)...
-
Log4jで機能毎に別ファイルへ出...
-
JAVAのServletで、画像表示につ...
-
PrintWriterとBufferedWriterの...
-
System.out.printlnで出力バッファ
-
プールとスプールの違いがわか...
-
Java配列でNullPointerExceptio...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
System.err. printlnとSystem.o...
-
flush()とclose()について
-
Log4jで機能毎に別ファイルへ出...
-
System.out.printlnの出力先
-
Javaで改行などが出来ないのです。
-
1~100までの数字を表示し、か...
-
system.out.printが出力されない
-
Eclipseのコンソールを常に表示...
-
1~100までの数字を表示したい
-
StringBufferで改ページ処理を...
-
JavaScriptの変数をjavaのメソ...
-
Log4Jではログを改行できない?
-
javaにおけるCSV出力時の文字コ...
-
テキストエリアで改行する
-
switch分が機能しません。
-
Tomcatが無応答となる現象が起...
-
一定のスペースを空けて端を揃...
-
JAVAのServletで、画像表示につ...
-
バイトスワップ
-
InputStreamはreadが1回しかで...
おすすめ情報