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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

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

Eclipse

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

servlet

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

Q&A

解決済

1回答

894閲覧

ServletでSQLの結果をロジックからコントローラに返却する仕様に変更したいです。

Yakusugi

総合スコア123

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

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

Eclipse

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

servlet

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

0グッド

0クリップ

投稿2021/11/19 02:32

Servlet/MySQLを使ってログイン画面を作成しています。

LoginServlet.java(コントローラ側)とLoginServeltLogic.java(ロジック側)に分けているのですが、
まだコントローラ側にロジックの処理が残ってしまっています。
具体的には、
1: 入力されたパラメータでDBを検索する(userid , password でdbを検索)
2: 検索結果が1件なら成功、0件なら失敗

現時点ですと、2をコントローラ側で行っている形になっており、
可能であれば2もロジック側で行いたいです。

もう少し具体的にいうと、ログイン可否をロジックからコントローラ側に返却する形にしたいのですが、
ヒントなどがあれば、ご回答頂けますと幸いです。
よろしくお願いいたします。

LoginServlet.java
```ここに言語を入力
package budget_tracker.login;

import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

import javax.naming.InitialContext;
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.sql.DataSource;

/**

  • Servlet implementation class LoginServlet

*/
@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
LoginServletLogic loginServletLogic;
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rset = null;

// データソースの作成 DataSource ds; // 初期化処理 public void init() throws ServletException { try { // 初期コンテキストを取得 InitialContext ic = new InitialContext(); // ルックアップしてデータソースを取得 ds = (DataSource) ic.lookup("java:comp/env/jdbc/searchman"); } catch (Exception e) { } finally { try { // just in case, terminate the DB connection with finally statement conn.close(); } catch (Exception e) { } } } /** * @see HttpServlet#HttpServlet() */ public LoginServlet() { super(); // TODO Auto-generated constructor stub } /** * @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 // setting text code request.setCharacterEncoding("Windows-31J"); // get the id in index.jsp String inputId = request.getParameter("id"); // get the password in index.jsp String inputPassword = request.getParameter("password"); System.out.println(inputId); System.out.println(inputPassword); try { loginServletLogic = new LoginServletLogic(); rset = (ResultSet) loginServletLogic.login(inputId, inputPassword);

// transfer the data to the transition page(put it by Attribute)
request.setAttribute("SqlResult", rset);

// move on to loginResult.jsp or loginResultFailed.jsp if (rset.next()) { request.getRequestDispatcher("mainSearch.jsp").forward(request, response); } else { request.getRequestDispatcher("loginFailed.jsp").forward(request, response); } // terminate the used objects rset.close(); pstmt.close(); conn.close(); } catch (Exception e) { e.printStackTrace(); doGet(request, response); } finally { try { // just in case, terminate the DB connection with finally statement conn.close(); } catch (Exception e) { } } }

}

LoginServletLogic.java ```ここに言語を入力 package budget_tracker.login; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import javax.naming.InitialContext; import javax.sql.DataSource; public class LoginServletLogic { ResultSet rset = null; DataSource ds; Connection conn = null; PreparedStatement pstmt = null; public ResultSet login(String inputId, String inputPassword) throws SQLException { try { // 初期コンテキストを取得 InitialContext ic = new InitialContext(); // ルックアップしてデータソースを取得 ds = (DataSource) ic.lookup("java:comp/env/jdbc/searchman"); // データソースからConnectionを取得 conn = ds.getConnection(); StringBuilder sql = new StringBuilder(); sql.append("select * from login_table where id = ? && password = ? "); pstmt = conn.prepareStatement(new String(sql)); pstmt.setString(1, inputId); pstmt.setString(2, inputPassword); rset = pstmt.executeQuery(); } catch (Exception e) { e.printStackTrace(); } return rset; } }

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2021/11/19 02:44

まず思ったように書いてみては。 赤の他人には何が問題なのか分かりません
dodox86

2021/11/19 03:03

動くと言えば動くのかもしれませんけど、取得したResultSetをmainSearch.jspにforward()したり、DBコネクションやトランザクションの取り回しが心配になる作りに見えますが、今はそういうのもアリなのでしょうか。
guest

回答1

0

ベストアンサー

public ResultSet login(String inputId, String inputPassword) throws SQLException {

public boolean login(String inputId, String inputPassword) throws SQLException {

に変えて、コントローラでやっている処理

rset.next()

の結果(と、ResultSetのクローズ処理)をLogic側で書けばよいのでは?

コントローラ側は

java

1if (loginServletLogic.login(inputId, inputPassword)) { 2 request.getRequestDispatcher("mainSearch.jsp").forward(request, response); 3} else { 4 request.getRequestDispatcher("loginFailed.jsp").forward(request, response); 5}

みたいになるんじゃないでしょうか。

request.setAttribute("SqlResult", rset);

の部分は、どうなるかは気になりますが・・・

投稿2021/11/19 07:57

momon-ga

総合スコア4826

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問