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

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

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

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

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

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

servlet

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

解決済

Java Servlet & Jsp ログイン証認 ユーザの権限によって表示させる内容を変える処理の実装に困っています。お力をお貸しください!!

RYU
RYU

総合スコア10

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

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

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

servlet

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

2回答

0評価

0クリップ

1093閲覧

投稿2022/08/01 02:56

編集2022/08/05 11:34

質問内容

現在、簡易的なログイン証認機能の実装をしているのですが、ユーザの権限によって表示させる内容を変える処理の実装に困っています。具体的な状況を説明しますと、まず、ユーザーにはSTAFF_DESCの”店舗”と”商品部”の二種類のユーザーがMySQLのMST_STAFFテーブルで定義されています。今回は、ログインしたユーザーをSTAFF_DESCの内容(店舗スタッフが商品部スタッフ)によってmenu.jspにある"ユーザー登録画面"のリンクを表示/非表示にしたいです。その為、menu.jspの方に<c:if>で条件がTrueだったらリンクを表示させるという処理を書き、LoginServlet.javaの方に新しいSQL文、新しい条件式を追記したのですが、<c:if>がTrueになっていないのか、商品部スタッフの場合でも"ユーザー登録画面"のリンクが表示されなくて困っています。
どこをどのようになおせばいいのか分からなかったので、また質問させて頂くことにしました。
ご教授頂ければ幸いです。宜しくお願いします。

スタッフ区分を判断する処理 → LoginAuthentication.javaの"user_authority"が"0"なら店舗スタッフ、"1"なら商品部スタッフと判断する条件式をLoginServlet.javaの53行目に記述。

ログインID : user1 → 店舗スタッフ(munu.jspの"ユーザー登録画面"のリンクを非表示)
ログインID : user3 → 商品部スタッフ(munu.jspの"ユーザー登録画面"のリンクを表示)

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

本来のメニュー画面 - user3 (menu.jsp)
イメージ説明

ログイン画面 - user1 (index.jsp)
イメージ説明

ログイン証認後のメニュー画面 - user1 (menu.jsp)
ー User1(店舗スタッフ)なのに"ユーザー登録画面"が表示されない。
イメージ説明

ログイン画面 - user3 (index.jsp)
イメージ説明

ログイン証認後のメニュー画面 - user3 (menu.jsp)
イメージ説明

MST_USERテーブルとMST_STAFFテーブルを結合し取得(LoginServlet.javaの27行目)
イメージ説明

該当のソースコード

index.jsp

Java

<%@ page language="java" contentType="text/html; charset=Windows-31J" pageEncoding="Windows-31J" isELIgnored="false"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <html> <head><meta charset="UTF-8"> <link rel="stylesheet" type="text/css" href="<%=request.getContextPath() %>/login.css"> <title>Insert title here</title> </head> <body> <h3>ログイン画面</h3> <p> <c:if test="${!empty errorMessages}"> <font color="red">ログインIDかパスワードが間違っています。<br>再度入力して下さい。</font> </c:if> <form method="POST" action="authentication" name="login_form"> <div class="login_form_input"> ログインID : <input type="text" name="user_id"><br> パスワード : <input type="password" name="user_pass"> </div> <button type="submit" name="submit">ログイン</button> </form> </body> </html>

LoginServlet.java

Java

package servlet; import java.io.IOException; 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 javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import authentications.LoginAuthentication; @WebServlet(urlPatterns = {"/authentication"}) public class LoginServlet extends HttpServlet{ private static final long serialVersionUID = 1L; @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { try { String sql = "select * from mst_user user join mst_staff staff on user.staff_kbn = staff.staff_kbn where user.user_id = ? and user.user_pass = ?;"; Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/imada?serverTimezone=Asia/Tokyo","root","ryugo3849"); PreparedStatement ps = connection.prepareStatement(sql); LoginAuthentication authen = new LoginAuthentication(); authen.setUser_id(request.getParameter("login_form_id")); authen.setUser_pass(request.getParameter("login_form_pass")); ps.setString(1,authen.getUser_id()); ps.setString(2,authen.getUser_pass()); ResultSet rs = ps.executeQuery(); List<LoginAuthentication> users = toUserList(rs); if (users.isEmpty() == true) { List<String> messages = new ArrayList<String>(); messages.add("ログインに失敗しました。"); request.setAttribute("errorMessages", messages); getServletContext().getRequestDispatcher("/index.jsp").forward(request,response); } else if (2 <= users.size()) { throw new IllegalStateException("2 <= userList.size()"); } else { request.getSession().setAttribute("login", users.get(0)); getServletContext().getRequestDispatcher("/menu.jsp").forward(request,response); } //変更箇所 var user = users.get(0); //データベースから取得したgetStaff_descの値がauthorityと同じ(商品部)だったらuser_authorityを1にする。 //LoginAuthenticationで定義。 if(user.getStaff_desc().equals(user.authority)){ user.user_authority = 1; request.setAttribute("authority", user); getServletContext().getRequestDispatcher("/menu.jsp").forward(request,response); }else { user.user_authority = 0; request.setAttribute("authority", user); getServletContext().getRequestDispatcher("/menu.jsp").forward(request,response); } rs.close(); ps.close(); connection.close(); } catch (Exception e) { e.printStackTrace(); } } private List<LoginAuthentication> toUserList(ResultSet rs) throws SQLException{ List<LoginAuthentication> ret = new ArrayList<LoginAuthentication>(); try { while (rs.next()) { String user_id = rs.getString("user_id"); String staff_desc = rs.getString("staff_desc"); LoginAuthentication user = new LoginAuthentication(); user.setUser_id(user_id); user.setStaff_desc(staff_desc); ret.add(user); } } catch (Exception e) { e.printStackTrace(); } return ret; } }

menu.jsp

Java

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" errorPage="/error_page.jsp"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <html> <head> <link rel="stylesheet" type="text/css" href="<%=request.getContextPath() %>/menu.css"> <title>メニュー画面</title> </head> <body> <div class="header"> <div class="welcome">ようこそ${login.user_id}さん</div> <div class="logout"> <form action="logout" method="post" class="top"> <input type="submit" name="submit" value="ログアウト"/> </form> </div> </div> <h3>メニュー画面</h3> <ul> <li><a href="sales_detail_check.jsp">売上実績参照画面</a></li>     //user_authorityが1(商品部ユーザーだったらリンクを表示する) <c:if test="${authority.user_authority == 1 }"> <li><a href="#">ユーザー登録画面</a></li>     </c:if> <li><a href="#">売上実績サマリ確認画面</a></li> </ul> </body> </html>

LoginAuthentication.java

Java

package authentications; public class LoginAuthentication { private String user_id; private String user_pass; private String staff_desc; public String authority = "商品部"; public int user_authority = 0; public String getUser_id() { return user_id; } public void setUser_id(String user_id) { this.user_id = user_id; } public String getUser_pass() { return user_pass; } public void setUser_pass(String user_pass) { this.user_pass = user_pass; } public String getStaff_desc() { return staff_desc; } public void setStaff_desc(String staff_desc) { this.staff_desc = staff_desc; } }

web.xml

<?xml version="1.0" encoding="Windows-31J"?> <web-app xmlns="https://jakarta.ee/xml/ns/jakartaee_9.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="https://jakarta.ee/xml/ns/jakartaee https://jakarta.ee/xml/ns/jakartaee/web-app_5_0.xsd" version="5.0"> <servlet> <servlet-name>LoginServlet</servlet-name> <servlet-class>servlet.LoginServlet</servlet-class> </servlet> <servlet> <servlet-name>LogoutServlet</servlet-name> <servlet-class>servlet.LogoutServlet</servlet-class> </servlet> <servlet> <servlet-name>LoginAuthentication</servlet-name> <servlet-class>authentication.LoginAuthentication</servlet-class> </servlet> <servlet-mapping> <servlet-name>LoginServlet</servlet-name> <url-pattern>/servlet/LoginServlet</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>LogoutServlet</servlet-name> <url-pattern>/servlet/LogoutServlet</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>LoginAuthentication</servlet-name> <url-pattern>/authentication/LoginAuthentication</url-pattern> </servlet-mapping> <session-config> <session-timeout>30</session-timeout> </session-config> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app>

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

Windows - 10
Microsoft Edge - 103.0.1264.62
Java - 17
Tomcat - 9
MySQL -8.0
mysql-connector-java - 8.0.29

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

m.ts10806

2022/08/01 03:02

各ユーザのデータはどうなってるのでしょう。 また想定の情報はすべて(権限部分も含めて)取得できているのでしょうか? デバッグモードでご確認ください。
RYU

2022/08/01 03:07

ユーザーのデータベースについても追記します。 確認してみます!

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

JSP

JSP(Java Server Pages)とは、ウェブアプリケーションの表示レイヤーに使われるサーバーサイドの技術のことです。

Java

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

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

servlet

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