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

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

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

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

Java

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

servlet

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

Q&A

解決済

1回答

9506閲覧

After end of result setというエラー

l_l_l_l_l_l_l_l

総合スコア38

MySQL

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

Java

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

servlet

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

0グッド

0クリップ

投稿2016/06/17 00:57

###前提・実現したいこと
ログイン画面でdelete_flagが1ならログインさせず、
それ以外ならさせるという処理を組み立てています。
しかし以下のようなエラーが出て困っています。
ご教授をお願い致します。

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

重大: Servlet.service() for servlet [servlet.loginservlet] in context with path [/Library] threw exception [java.sql.SQLException: After end of result set] with root cause

###servlet

package servlet; 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.servlet.http.HttpSession; import javax.sql.DataSource; /** * Servlet implementation class loginservlet */ @WebServlet("/loginservlet") public class loginservlet extends HttpServlet { private static final long serialVersionUID = 1L; /** * @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 } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse * response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub Connection con = null; PreparedStatement ps = null; String sql = null; ResultSet rs = null; String userid = request.getParameter("userid"); String pass = request.getParameter("pass"); if (userid == null || userid.length() == 0) { request.setAttribute("errorMessage", "ユーザ名が未入力です"); this.getServletContext().getRequestDispatcher("/Login.jsp") .forward(request, response); } else if (pass == null || pass.length() == 0) { request.setAttribute("errorMessage", "パスワードが未入力です"); this.getServletContext().getRequestDispatcher("/Login.jsp") .forward(request, response); } else { try { InitialContext initContext = new InitialContext(); DataSource ds = (DataSource) initContext .lookup("java:comp/env/jdbc/Library"); con = ds.getConnection(); sql = "SELECT * FROM user"; ps = con.prepareStatement(sql); rs = ps.executeQuery(); boolean userResult = false; boolean ad = false; while (rs.next()) { String dbuserid = rs.getString("user_id"); String dbpassword = rs.getString("password"); if (dbuserid.equals(userid) && dbpassword.equals(pass)) { userResult = true; if ("1".equals(rs.getString("admin"))) { ad = true; } } } String delete_flg = rs.getString("delete_flg"); int int_df = Integer.parseInt(delete_flg); if (userResult) { HttpSession session = request.getSession(); session.setAttribute("userResult", userResult); session.setAttribute("admin", ad); session.setAttribute("user_id", userid); if (ad == true) { this.getServletContext() .getRequestDispatcher("/kanri_mypage.jsp") .forward(request, response); } else { this.getServletContext() .getRequestDispatcher("/user_mypage.jsp") .forward(request, response); } } else if (int_df != 0) { request.setAttribute("errorMessage", "そのユーザは存在しません"); this.getServletContext().getRequestDispatcher("/Login.jsp") .forward(request, response); } else { request.setAttribute("errorMessage", "ユーザ名またはパスワードが違います"); this.getServletContext().getRequestDispatcher("/Login.jsp") .forward(request, response); } } catch (Exception e) { request.setAttribute("errorMessage", "システムエラーが発生しました。"); this.getServletContext().getRequestDispatcher("/Login.jsp") .forward(request, response); throw new ServletException(e); } finally { try { if (rs != null) { rs.close(); } if (ps != null) { ps.close(); } if (con != null) { con.close(); } } catch (Exception e) { } } } } }

###JSP

<%@ page import="java.sql.*,javax.naming.*,javax.sql.*" contentType="text/html; charset=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> <link rel="stylesheet" type="text/css" href="css/Library.css"> <title>ログイン</title> </head> <body> <form method="POST" action="loginservlet"> <br> <div> ユーザ I D : <input type="text" name="userid" /> </div> <br> <div> パスワード : <input type="password" name="pass" /> </div> <br> <div> <button class="button" type="submit" style="float: left">ログイン</button> <button class="button" type="reset">クリア</button> </div> </form> <c:if test="${!empty requestScope['errorMessage']}"> <div>${requestScope['errorMessage']}</div> </c:if> </body>

###補足情報(言語/FW/ツール等のバージョンなど)
情報が足りないのでしたらお申し付けください。
その際は追記いたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

そのエラーはResultSetのレコードを全て読み終わっているのに、その後にまだデータを受け取ろうとした時に起こります。rs.next()がtrueである間しかrs.get~~~は使ってはいけません。

Java

1while (rs.next()) { 2 // ここでしかrs.getXXXを使ってはいけない 3} 4String delete_flg = rs.getString("delete_flg"); // ここはアウト

補足

そもそもユーザを全件取ってきて、IDとパスワードが一致しているユーザを探すというのが非効率過ぎます。今欲しい情報は該当ユーザ1件なので、WHERE句で絞り込めば1件だけ取ってこれます。

Java

1 2sql = "SELECT * FROM user WHERE user_id = ? AND password = ?"; 3ps = con.prepareStatement(sql); 4ps.setString(1, userid); 5ps.setString(2, pass); 6rs = ps.executeQuery(); 7 8boolean userResult = false; 9boolean ad = false; 10int int_df = 0; 11if(rs.next()) { 12 // IDとパスワードが一致するユーザが見つかった 13 userResult = true; 14 if(rs.getString("admin").equals("1")) { 15 ad = true; 16 } 17 int_df = Integer.parseInt(rs.getString("delete_flg")); 18}

投稿2016/06/17 01:08

masaya_ohashi

総合スコア9206

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問