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

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

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

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

JSP

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

Java

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

Eclipse

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

servlet

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

Q&A

解決済

2回答

1786閲覧

JavaのNullPointerExceptionを解決したいです。

Yakusugi

総合スコア123

JDBC

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

JSP

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

Java

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

Eclipse

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

servlet

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

0グッド

0クリップ

投稿2021/11/23 03:24

Servletでログイン画面を作成しています。
LoginServlet.java(コントローラ)でユーザ名、パスワードを受け取り、
受け取った変数をLoginServletLogin.java(ロジック)に渡し、
ロジック側でログイン可否をbooleanで判定し、
その結果をもってコントローラでログイン成功画面、またはログイン失敗画面へと移行する形にしたいのですが、
java.lang.NullPointerExceptionが出てしまいます。
デバッグモードで、変数inputId, inputPasswordにそれぞれJSPで受け取った値が入っている事は確認済みなのですが、
何が原因でNullPointerExceptionが出ているのかが掴み切れていません。
大変お手数ですが、解決の為、ヒントを頂けますと幸いです。

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; boolean sqlResult = false; // データソースの作成 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 { // move on to loginResult.jsp or loginResultFailed.jsp if (loginServletLogic.login(inputId, inputPassword)) { 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; boolean sqlResult = false; public boolean 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(); if (rset.next()) { sqlResult = true; } else { sqlResult = false; } } catch (Exception e) { e.printStackTrace(); } return sqlResult; } }

エラー内容
java.lang.NullPointerException
at budget_tracker.login.LoginServlet.doPost(LoginServlet.java:98)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:660)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:494)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:651)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:407)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:754)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1376)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Unknown Source)

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

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

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

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

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

guest

回答2

0

自己解決

LoginServlet.javaでLoginServletLogic loginServletLogic;変数を作成した際に、中身となるインスタンスを作成していなかった為、上記エラーが起きていました。
解決しました。

投稿2021/11/27 09:52

Yakusugi

総合スコア123

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

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

0

何が原因でNullPointerExceptionが出ているのかが掴み切れていません。

Exceptionなどのエラーが出たら、そのエラーメッセージを丁寧に読みましょう。エラー内容を読むと

at budget_tracker.login.LoginServlet.doPost(LoginServlet.java:98)

とあります。LoginServlet.javaの98行目です。質問に提示されたLoginServlet.javaをそのまま読むと、98行目はrset.close();です。ではrsetは何かと言うと、同じくLoginServlet.javaの26行目、ResultSet rset = null; で、nullをセットしたまま適切なインスタンスがセットされることなく使われています。

そのせいです。

投稿2021/11/23 03:40

dodox86

総合スコア9183

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

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

dodox86

2021/11/23 03:55

そもそも、LoginServletのdoPostメソッドで、 > rset.close(); > pstmt.close(); > conn.close(); のコードはいらないのでは? rsetに限らず、connもpstmtも使っていませんね。LoginServletLogicクラスに処理を移動させたかなどして、その名残りでしょうか。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問