この画像のコメント入力欄の下に,コメントした履歴を出力できません、JSTLのcoreタグで書いているはずなのに、なぜ出力されないのでしょうか?
Main.java(servlet)のコードです。追加しました。どうぞよろしくお願いします。
package servlet;
import java.util.List;
import javax.servlet.RequestDispatcher;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import model.GetMutterListLogic;
import model.Mutter;
import model.User;
import model.PostMutterLogic;
/**
* Servlet implementation class Main
*/
@WebServlet("/Main")
public class Main extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//つぶやきリストを取得して、リクエストスコープに保存
GetMutterListLogic getMutterListLogic=new GetMutterListLogic();
List<Mutter>mutterList=getMutterListLogic.execute();
request.setAttribute("mutterList", mutterList);
//ログインしているか確認するため
//セッションスコープからユーザー情報を取得
HttpSession session=request.getSession();
User loginUser=(User)session.getAttribute("loginUser");
if(loginUser==null){//ログインしていない場合
//リダイレクト
response.sendRedirect("/docoTsubuu/");
}else{//ログイン済みの場合
//フォワード
RequestDispatcher dispatcher=request.getRequestDispatcher("/WEB-INF/jsp/main.jsp");
dispatcher.forward(request, response);
}
}
protected void doPost(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException{
//リクエストパラメータの取得
request.setCharacterEncoding("UTF-8");
String text=request.getParameter("text");
//入力値チェック
if(text!=null&&text.length()!=0){
//セッションスコープに保存されたユーザー情報を取得
HttpSession session=request.getSession();
User loginUser=(User)session.getAttribute("loginUser");
//つぶやきをつぶやきリストに追加
Mutter mutter=new Mutter(loginUser.getName(),text);
PostMutterLogic postMutterLogic=new PostMutterLogic();
postMutterLogic.execute(mutter);
//つぶやきリストを習得して、リクエストスコープに保存
GetMutterListLogic getMutterListLogic=new GetMutterListLogic();
List<Mutter> mutterList=getMutterListLogic.execute();
request.setAttribute("mutterList", mutterList);
}else{
//エラーメッセージをリクエストスコープに保存
request.setAttribute("errorMsg", "つぶやきが入力されていません");
}
//メイン画面にフォワード
RequestDispatcher dispatcher=request.getRequestDispatcher("/WEB-INF/jsp/main.jsp");
dispatcher.forward(request, response);
// TODO Auto-generated method stub
response.getWriter().append("Served at: ").append(request.getContextPath());
}
}
main.jspのコードです。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>どこつぶ</title>
</head>
<body>
<h1>どこ粒メイン</h1>
<p>
<c:out value="${loginUser.name}"/>さん、ログイン中
<a href="/docoTsubuu/Logout">ログアウト</a>
</p>
<p><a href="/docoTsubuu/Main">更新</a></p>
<form action="/docoTsubuu/Main"method="post">
<input type="text"name="text">
<input type="submit" value="つぶやく">
</form>
<c:if test="${not empty errorMsg}">
<p>${errorMsg}</p>
</c:if>
<c:forEach var="mutter" items="${mutterList}">
<p><c:out value="${mutter.userName}"/>:
<c:out value="${mutter.text}"/></p>
</c:forEach>
</body>
</html>
MutterDAOです
package dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import model.Mutter;
public class MutterDAO {
private final String DRIVER_NAME="org.h2.Driver";
private final String JDBC_URL="jdbc:h2:file:/User/taichi/Documents/networkspace/docoTsubuu/h2data.dat";
private final String DB_USER="sa";
private final String DB_PASS="";
public List<Mutter> findAll(){
Connection conn=null;
List<Mutter>mutterList=new ArrayList<Mutter>();
try{
Class.forName(DRIVER_NAME);
conn=DriverManager.getConnection(JDBC_URL,DB_USER,DB_PASS);
//SELECT文の準備
String sql="SELECT ID,NAME,TEXT FROM MUTTER ORDER BY ID DESC";
PreparedStatement pStmt=conn.prepareStatement(sql);
//SELECTを実行
ResultSet rs=pStmt.executeQuery();
//SELECT文の結果をArrayList二格納
while(rs.next()){
int id=rs.getInt("ID");
String userName=rs.getString("NAME");
String text=rs.getString("NAME");
Mutter mutter=new Mutter(id,userName,text);
mutterList.add(mutter);
}
}catch(SQLException e){
e.printStackTrace();
return null;
}catch(ClassNotFoundException e){
e.printStackTrace();
return null;
}finally{
//データベース切断
if(conn!=null){
try{
conn.close();
}catch(SQLException e){
e.printStackTrace();
return null;
}
}
}
return mutterList;
}
public boolean create(Mutter mutter){
Connection conn=null;
try{
//データベースへ接続
conn=DriverManager.getConnection(JDBC_URL,DB_USER,DB_PASS);
//INSERT文の準備(idは自動連番なので指定しなくてもいい)
String sql="INSERT INTO MUTTER(NAME,TEXT)VALUES(?,?)";
PreparedStatement pStmt=conn.prepareStatement(sql);
//INSERT文中の「?」二使用する値を設定しSQLを完成
pStmt.setString(1, mutter.getUserName());
pStmt.setString(2, mutter.getText());
//INSERT文を実行
int result=pStmt.executeUpdate();
if(result !=1){
return false;
}
}catch(SQLException e){
e.printStackTrace();
return false;
}finally{
//データベース切断
if(conn!=null){
try{
conn.close();
}catch(SQLException e){
e.printStackTrace();
}
}
}
return true;
}
}
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.32%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
質問への追記・修正、ベストアンサー選択の依頼
tkturbo
2016/04/13 10:04
Main.javaのソースも張っていただけないとコメントのしようもありません。
edoooooo
2016/04/13 17:52
すみませんでした。どうぞよろしくお願いします。