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

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

ただいまの
回答率

87.49%

フォローした人はフォロー解除ボタンを表示させたい

受付中

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 2,493

score 58

サーブレット

//フォロー登録に関するリクエストを処理するコントローラ

package servlet;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import model.FollowLogic;
import model.User;

@WebServlet("/FollowServlet")
public class FollowServlet extends ServletBase {
    private static final long serialVersionUID = 1L;

    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        // ログインユーザの取得
        User loginUser = getLoginUser(request);

        // リクエストパラメータの取得
        request.setCharacterEncoding("UTF-8");
        String sFollowId = request.getParameter("followId");
        int followId = Integer.parseInt(sFollowId);

        // フォロー処理 FOLLOWテーブルに追加
        FollowLogic logic = new FollowLogic();
        logic.execute(loginUser.getUserId(), followId);

        // フォロー完了画面にフォワード
        forward("WEB-INF/jsp/followConfirm.jsp", request, response);

    }
}

DAO

package dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;

import model.FollowViewModel;
import util.JDBCUtils;

public class FollowDAO {

    // FOLLOWテーブルに追加する
    public void follow(int userId, int followId) {
        try (Connection conn = JDBCUtils.getConnection()) {

            String sql = "INSERT INTO FOLLOW (USER_ID, FOLLOW_ID) VALUES (?,?)";
            try (PreparedStatement pStmt = conn.prepareStatement(sql)) {
                // INSERT文中の「?」に使用する値を設定しSQLを完成
                pStmt.setInt(1, userId);
                pStmt.setInt(2, followId);

                // INSERT文を実行
                int result = pStmt.executeUpdate();
                if (result != 1) {
                    throw new RuntimeException("フォローに失敗しました。");
                }
            }
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }

    // 指定したuser_Id のフォロー数を取得
    public int getFollowCount(int userId) {
        int followCount = 0;

        try (Connection conn = JDBCUtils.getConnection()) {

            // FOLLOWテーブルからログインユーザーのフォローの数を表示
            String sql = "SELECT COUNT (*) AS FOLLOWCOUNT FROM FOLLOW WHERE USER_ID = ?";

            try (PreparedStatement pStmt = conn.prepareStatement(sql)) {
                // INSERT文中の「?」に使用する値を設定しSQLを完成
                pStmt.setInt(1, userId);
                // SELECTを実行
                try (ResultSet rs = pStmt.executeQuery()) {

                    // 1件しか返って来ないのでif文
                    if (rs.next()) {
                        followCount = rs.getInt("FOLLOWCOUNT");
                    }
                }
            }
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
        return followCount;
    }

    // 指定したuser_Id のフォロワー数を取得
    public int getFollowerCount(int userId) {
        int followerCount = 0;

        try (Connection conn = JDBCUtils.getConnection()) {

            // FOLLOWテーブルからログインユーザーのフォロワーの数を表示
            String sql = "SELECT COUNT (*) AS FOLLOWERCOUNT FROM FOLLOW WHERE FOLLOW_ID = ?";

            try (PreparedStatement pStmt = conn.prepareStatement(sql)) {

                pStmt.setInt(1, userId);
                // SELECTを実行
                try (ResultSet rs = pStmt.executeQuery()) {

                    if (rs.next()) {
                        followerCount = rs.getInt("FOLLOWERCOUNT");

                    }
                }
            }
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
        return followerCount;
    }

    // 指定したuser_Idのフォロー 一覧の取得
    public List<FollowViewModel> getFollowList(int userId) {
        List<FollowViewModel> followList = new ArrayList<FollowViewModel>();

        try (Connection conn = JDBCUtils.getConnection()) {

            // フォローしたユーザーの取得(自分は表示しない)
            String sql = "SELECT USER.USER_ID AS USER_ID, USER.USER_NAME AS USER_NAME FROM USER "
                    + "INNER JOIN FOLLOW ON USER.USER_ID = FOLLOW.FOLLOW_ID " + "WHERE FOLLOW.USER_ID = ?";

            try (PreparedStatement pStmt = conn.prepareStatement(sql)) {

                pStmt.setInt(1, userId);

                // SELECTを実行
                try (ResultSet rs = pStmt.executeQuery()) {
                    // SELECT文の結果をArrayListに格納
                    while (rs.next()) {
                        int followUserId = rs.getInt("USER_ID");
                        String followUserName = rs.getString("USER_NAME");

                        FollowViewModel follow = new FollowViewModel(followUserId, followUserName);
                        followList.add(follow);
                    }
                }
            }
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
        return followList;
    }

    // 指定したuser_Idのフォロワー 一覧の取得
    public List<FollowViewModel> getFollowerList(int userId) {
        List<FollowViewModel> followerList = new ArrayList<FollowViewModel>();

        try (Connection conn = JDBCUtils.getConnection()) {

            // フォローしたユーザーの取得(自分は表示しない)
            String sql = "SELECT USER.USER_ID AS USER_ID, USER.USER_NAME AS USER_NAME FROM USER "
                    + "INNER JOIN FOLLOW ON USER.USER_ID = FOLLOW.USER_ID " + "WHERE FOLLOW.FOLLOW_ID = ?";

            try (PreparedStatement pStmt = conn.prepareStatement(sql)) {

                pStmt.setInt(1, userId);

                // SELECTを実行
                try (ResultSet rs = pStmt.executeQuery()) {
                    // SELECT文の結果をArrayListに格納
                    while (rs.next()) {
                        int followerUserId = rs.getInt("USER_ID");
                        String followerUserName = rs.getString("USER_NAME");

                        FollowViewModel follower = new FollowViewModel(followerUserId, followerUserName);
                        followerList.add(follower);
                    }
                }
            }
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
        return followerList;
    }

    // フォローを解除する
    public void followDelete(int userId, int followId) {
        try (Connection conn = JDBCUtils.getConnection()) {

            String sql = "DELETE FROM FOLLOW WHERE USER_ID = ? AND FOLLOW_ID = ?";
            try (PreparedStatement pStmt = conn.prepareStatement(sql)) {
                // INSERT文中の「?」に使用する値を設定しSQLを完成
                pStmt.setInt(1, userId);
                pStmt.setInt(2, followId);

                // INSERT文を実行
                int result = pStmt.executeUpdate();
                if (result != 1) {
                    throw new RuntimeException("フォロー解除に失敗しました。");
                }
            }
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }

}

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>
<html>
<head>
<meta charset="UTF-8">
<title>どこつぶ</title>
<link rel="stylesheet" type="text/css"
    href="${pageContext.request.contextPath}/css/style.css">
</head>
<body>
    <jsp:include page="header.jsp"/>
    <div id="name-bar">
        <p class="name">
            <c:out value="${loginUser.userName}" />
        </p>
        <a href="${pageContext.request.contextPath}/FollowList" class="follow-font">フォロー</a>
        <a class=follow-count>
            <c:out value="${countData.followCount}" /> <!-- リクエストスコープ request.setAttribute("followCount", followCount);-->
        </a>
        <br>
        <a href="${pageContext.request.contextPath}/FollowerList" class="follow-font">フォロワー</a>
        <a class=follow-count>
            <c:out value="${countData.followerCount}" />
        </a>
        <br>
        <a href="${pageContext.request.contextPath}/FavoriteList" class="follow-font">お気に入り</a>
        <a class=follow-count>
            <c:out value="${countData.favoriteCount}" />
        </a>
        <form action="${pageContext.request.contextPath}/Main" method="post">
            <textarea name="text" rows="6" class="tweet-form" placeholder="つぶやく内容を入力してください。"></textarea>
            <br> <input type="submit" value="つぶやく" class="tweet-button">
        </form>
        <c:if test="${not empty errorMsg}">
            <p>${errorMsg}</p>
        </c:if>
    </div>
    <div id="tweet-bar">
        <p class=tweet-title><つぶやき一覧></p>
        <c:forEach var="mutter" items="${mutterList}">
            <p class="tweet-user-name">
                <c:out value="${mutter.userName}" />
            </p>
            <pre class="tweet"><c:out value="${mutter.text}" />
            </pre>
            <div class=follow>
                <form action="${pageContext.request.contextPath}/FavoriteServlet"
                    method="post">
                    <input type="hidden" name="tweetId" value="${mutter.tweetId}">  <!-- name=部品の名前 value=送信されるデータ -->
                    <input type="submit" value="お気に入り登録する" class="follow-button">
                </form>
            </div>
        </c:forEach>
    </div>
    <div id="user-bar">
        <p class=user-list-title><オススメユーザー></p>

        <c:forEach var="user" items="${userList}">
            <p class="user-list-name">
            <div class=user>
                <form action="${pageContext.request.contextPath}/OtherUsersServlet"
                    method="post">
                    <input type="hidden" name="followId" value="${user.userId}">
                    <input type="submit" value="${user.userName}" class="user-list-name">
                </form>
            </div>
            <div class=follow>
                <form action="${pageContext.request.contextPath}/FollowServlet"
                    method="post">
                    <input type="hidden" name="followId" value="${user.userId}">
                    <input type="submit" value="フォローする" class="follow-button">
                </form>
            </div>
        </c:forEach>
    </div>
</body>
</html>

現在フォローした人にもフォローするボタンが表示されるのですが
フォローした人にはフォロー解除ボタンを表示させたいのですが
サーブレットにどのようなif文を書けばいいのでしょうか??

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

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

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

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

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

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

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

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

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • m.ts10806

    2017/06/07 11:01

    見た感じjspの方ではフォロー・フォロワーは数だけでオススメユーザーしか並べてないようですが・・。

    キャンセル

回答 1

0

こんにちは
初めにこの質問に対する答えを私は持っていません
しかし私も同じ問題を抱えています
そこでよければですが私とアイデアを交換しあいませんか?
もっともこのメッセージをご覧頂けていたら、ですが...
一応以下に私が今考えている仮の実装案を記載しておきます

・データベースから既存のコメントを取得する際、フォローしているユーザーのIDをリストで取得し、
jsp側で対象のユーザーのIDと合致するか判定させる
問題点:新しく更新されたコメントへの対処が未定、単純にスマートさに欠ける

・データベースへの問い合わせの段階で判定し、結果を表示する
問題点:仮にデータベースでの処理が上手くいったとしても現在コメント取得はサーバー側で更新した情報を
非同期で自動的に取得させる方法をとっている為、ユーザーごとの対応は難しい

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 87.49%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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