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

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

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

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

Java

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

Eclipse

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

servlet

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

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

解決済

レスポンスをコミットした後でフォワードできませんと出てきます

wtp
wtp

総合スコア2

JSP

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

Java

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

Eclipse

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

servlet

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

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

1回答

0評価

0クリップ

6075閲覧

投稿2020/11/17 13:29

前提・実現したいこと

最近javaの学習を始めた者です。
javaでログイン画面を作っているのですが、ユーザー情報の登録画面で間違った形式で入力された時に
ログイン画面にエラー通知を表示させたいのですが上手くいきません。
エラー通知なしで登録だけで試すと上手くいくのですが、エラー通知のコードを書くとエラーになってしまいます。
エラーの内容からフォワードの使い方に難があるのだと思いますが、
原因がわからないのでご教授いただけませんでしょうか。

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

タイプ 例外報告 メッセージ レスポンスをコミットした後でフォワードできません 説明 サーバーは予期しない条件に遭遇しました。それはリクエストの実行を妨げます。 例外 java.lang.IllegalStateException: レスポンスをコミットした後でフォワードできません database.InsertCustomer.doPost(InsertCustomer.java:68) javax.servlet.http.HttpServlet.service(HttpServlet.java:652) javax.servlet.http.HttpServlet.service(HttpServlet.java:733) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) 注意 原因のすべてのスタックトレースは、サーバのログに記録されています

該当のソースコード

java

<%@ 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>Insert title here</title> <link rel="stylesheet" href="WEB-INF/style.css"> </head> <body> <form action="database/InsertCustomer" method = "POST"> ${param['errors']} <table> <tr> <th align="right">名前:</th> <td><input type="text" name="name" size=35 maxlength="20"></td> </tr> <tr> <th align="right">emailアドレス:</th> <td><input type="text" name="email" size=35 maxlength="50"></td> </tr> <tr> <th align="right">パスワード:</th> <td><input type="password" name="password" size=35 minlength="8" maxlength="15"></td> </tr> <tr> <th align="right">パスワード(確認用):</th> <td><input type="password" name="validation" size=35 minlength="8" maxlength="15"></td> </tr> <tr> <th align="right">住所:</th> <td><input type="text" name="address" size=35 maxlength="20"></td> </tr> <tr> <th align="right">電話番号:</th> <td><input type="text" name="tel" size=35 maxlength="15"></td> </tr> <tr> <td colspan="2"><input type="submit" value="登録"></td> </table> </form> </body> </html>

java

package database; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; /** * Servlet implementation class BaseServlet */ @WebServlet("/database/BaseServlet") public class BaseServlet extends HttpServlet { public Connection getConnection() { Connection con = null; String url = "jdbc:mariadb://localhost:3306/customer"; String user = "root"; String pass = "root"; try { con = DriverManager.getConnection(url, user, pass); } catch(SQLException e) { e.printStackTrace(); } catch(Exception e) { e.printStackTrace(); } return con; } }

java

package database; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; public class ErrorCheck extends BaseServlet { private ArrayList<String> errors = null; public ErrorCheck(){ this.errors = new ArrayList<String>(); } public void requiredCheck(String value, String name) { if(value == null || value.trim().isEmpty()) { this.errors.add(name + "は入力必須です"); } } public void regExpCheck(String value, String pattern, String name) { if(!value.matches(pattern)) { this.errors.add(name + "を正しい形式で入力して下さい"); } } public void passwordCheck(String value1, String value2) { if(!value1.matches("[\w-\./]{8,15}")){ this.errors.add("パスワードは半角英数字と記号(-./_)の組み合わせで入力して下さい"); } else if(value1 != value2) { this.errors.add("パスワードが一致しません"); } } public void duplicateCheck(String value, String name) { Connection con = null; PreparedStatement stmt = null; ResultSet rs = null; try { con = super.getConnection(); stmt = con.prepareStatement("SELECT * FROM customer WHERE email = ?"); stmt.setString(1, value); rs = stmt.executeQuery(); if(rs.next()) { this.errors.add(name + "が重複しています");} } catch(SQLException e) { e.printStackTrace(); } catch(Exception e) { e.printStackTrace(); } finally { try { if(rs != null) { rs.close(); } if(stmt != null) { stmt.close(); } if(con != null) { con.close(); } } catch(SQLException e) { e.printStackTrace(); } catch(Exception e) { e.printStackTrace(); } } } public boolean hasErrors() { return !this.errors.isEmpty(); } public String getErrorList() { StringBuffer buff = new StringBuffer(); buff.append("<ul style='color:red;'>"); for(String err : errors) { buff.append("<li>" + err + "</li>"); } buff.append("</ul>"); return buff.toString(); } }

java

package database; import java.io.IOException; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; import javax.servlet.RequestDispatcher; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * Servlet implementation class InsertCustomer */ @WebServlet("/database/InsertCustomer") public class InsertCustomer extends BaseServlet { /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub request.setCharacterEncoding("UTF-8"); String name = request.getParameter("name"); String email = request.getParameter("email"); String password = request.getParameter("password"); String validation = request.getParameter("validation"); String address = request.getParameter("address"); String tel = request.getParameter("tel"); String mailFormat = "[\w\.\-!#$\"\'%&()=^~¥|\[\]{}*+<>,?/]+@(?:[\w\-]+\.)+[\w\-]+"; String telFormat = "[0-9]{10,11}"; ErrorCheck errorCheck = new ErrorCheck(); errorCheck.requiredCheck(name, "名前"); errorCheck.regExpCheck(email, mailFormat, "メールアドレス"); errorCheck.passwordCheck(password, validation); errorCheck.regExpCheck(tel, telFormat, name); if(errorCheck.hasErrors()) { request.setAttribute("errors", errorCheck.getErrorList()); RequestDispatcher dispatch = request.getRequestDispatcher("http://localhost:8080/shopinfo/"); dispatch.forward(request, response); } PreparedStatement statement = null; Connection con = null; String sql = "INSERT INTO customer (name, email, password, address, tel) VALUES(?,?,?,?,?)"; try { con = super.getConnection(); statement = con.prepareStatement(sql); statement.setString(1, name); statement.setString(2, email); statement.setString(3, password); statement.setString(4, address); statement.setString(5, tel); statement.executeUpdate(); } catch(SQLException e) { e.printStackTrace(); } catch(Exception e) { e.printStackTrace(); } finally { try { if(statement != null) {con.close();} if(con != null) {con.close();} } catch(Exception e) { e.printStackTrace(); } finally { RequestDispatcher dispatch = request.getRequestDispatcher("http://localhost:8080/shopinfo/"); dispatch.forward(request, response); } } } }

xml

<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" id="WebApp_ID" version="4.0"> <display-name>shopinf</display-name> <welcome-file-list> <welcome-file>entryCustomer.jsp</welcome-file> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> </welcome-file-list> <servlet> <servlet-name>BaseServlet</servlet-name> <servlet-class>database.BaseServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>BaseServlet</servlet-name> <url-pattern>/BaseServlet</url-pattern> </servlet-mapping> <servlet> <servlet-name>InsertCustomer</servlet-name> <servlet-class>database.InsertCustomer</servlet-class> </servlet> <servlet-mapping> <servlet-name>InsertCustomer</servlet-name> <url-pattern>/InsertCustomer</url-pattern> </servlet-mapping> </web-app>

試したこと

フォワードをリダイレクトに変えて試してみたり、フォワードを書く位置を変えてみたりしました。

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

tomcat9.0でjava15、eclipse使用でPCはmacです。

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

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

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

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で作成されたプログラムです。 ショッピングサイトやオンラインバンキングといった、動的なウェブサイトの構築に用いられています。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。