動的Webプロジェクト④色々なForm
前回から続く動的Webプロジェクトについての連載です。
①サーブレット
②JSP
③Get/Post
④色々なForm(今回)
今回のテーマは、色々なFormについてです。
Formは、HTMLの仕様になるので、若干Javaとは話がそれますが、
Webアプリ開発においては、HTMLの知識も必要となるので、説明させて頂きます。
機能 | 記載例 | 補足説明 |
テキスト入力 | <input type="text" name="①" value="②"> | ①名前、②デフォルト表示 |
テキストエリア | <textarea rows="①" cols="②" name="③"> | ①列数、②文字数、③名前 |
ラジオボタン | <input type="radio" name="①" value="②">③ | ①名前、②送信される内容、③表示させる内容 |
チェックボックス | <input type="checkbox" name="①" value="②">③ | ①名前、②送信される内容、③表示させる内容 |
セレクト | <select name="①" size="②"> <option value="③">④ </select> | ①名前、②行数、③送信される内容、④表示させる内容 |
隠し項目 | <input type="hidden" name="①" value="②"> | ①名前、②送信される内容 |
送信ボタン | <input type="submit" name="①"> | ①ボタンに表示する文字 |
リセットボタン | <input type="reset" value="①"> | ①ボタンに表示する文字 |
①Webプロジェクトの作成(前回のものを流用のため不要)
②JSP側で、色々なフォームを作成
ServletGetPost/src/main/webapp/jspで右クリックして、新規→JSPを選択JSPのファイル名をVariousForm.jspにします。
data:image/s3,"s3://crabby-images/eb037/eb037113db0171eef4e93b0541cde411b6fa0dd6" alt=""
ここは、特に変更は不要です。完了ボタンを押下します。
data:image/s3,"s3://crabby-images/886a8/886a87e200f9bc7e64f3e3f5550d3fc5833333ad" alt=""
JSPのひな型が作成できました。
data:image/s3,"s3://crabby-images/7b1b6/7b1b624ba1f70615f2af36d6a11494e7e4c256d8" alt=""
以下のように、<body>~</body>部分のJSPを実装します。
formタグで、ServletVariousFormを宛先に指定して、postでリクエストします。
data:image/s3,"s3://crabby-images/eb975/eb975b16c34122dc3a158a495a5fba626a5dff9a" alt=""
③サーブレット側でdoPostメソッドを作成
data:image/s3,"s3://crabby-images/48e30/48e30680b55586d4dd662134f1200d71b2c2802f" alt=""
data:image/s3,"s3://crabby-images/96a07/96a0788a6972329aae56c8976448f51ecc7f5bee" alt=""
data:image/s3,"s3://crabby-images/04186/04186ec92f01f443ad3bab09e75434c4e90f610f" alt=""
data:image/s3,"s3://crabby-images/5c9c5/5c9c54f00b92fad23239b9e61ebdce400dda702b" alt=""
行数 | 説明 |
41 | ひな形の行でしたが、不要なのでコメントにしています。 |
42 | 文字コードをUTF-8に設定しています。 |
43 | Webページ出力用のオブジェクトを生成しています。 |
45 | リクエストに含まれる入力パラメータ名をすべて取得しています。 |
46 | パラメータ名が存在していれば、繰り返す条件です。 |
47 | パラメータ名を順番に取得します。 |
48 | パラメータの値を取得します。同じパラメータ名で複数値を持っている場合もあります。 |
49 | 値の個数分繰り返します。 |
50 | Webページに、パラメータ名+値を出力します。 |
data:image/s3,"s3://crabby-images/ecf25/ecf25fb9c892552fabae14e910b0c8f61f067cf6" alt=""
④Webプロジェクトのサーバー構成に追加(前回のものを流用のため不要)
これで、準備は整いました。では、サーバーを起動しましょう。以下のURLを打ってください。
以下の初期画面が表示します。では、実験してみましょう。
data:image/s3,"s3://crabby-images/36d72/36d726764196fd35098ed5efa27cb2c0d0d55a21" alt=""
実際に入力して、送信ボタンを押してみましょう。
data:image/s3,"s3://crabby-images/16c13/16c13e2aa5101c16635a12dc56db875d2461737e" alt=""
以下のように、結果をWebページに表示すれば成功です。
data:image/s3,"s3://crabby-images/b964a/b964aef0d5282eb4468ce8e5bd9db4a0520c6fbf" alt=""
■ソースコードのコピーペースト用に記載します。
ServletVariousForm.java
package app;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Enumeration;
import jakarta.servlet.ServletException;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
/**
* Servlet implementation class ServletVariousForm
*/
public class ServletVariousForm extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public ServletVariousForm() {
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
//doGet(request, response);
response.setContentType("text/plain; charset=UTF-8");
PrintWriter out =response.getWriter();
Enumeration nameList = request.getParameterNames();
while(nameList.hasMoreElements()) {
String name = nameList.nextElement();
String[] value = request.getParameterValues(name);
for(int i=0; i out.println(name+"="+value[i]);
}
}
}
}
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Enumeration;
import jakarta.servlet.ServletException;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
/**
* Servlet implementation class ServletVariousForm
*/
public class ServletVariousForm extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public ServletVariousForm() {
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
//doGet(request, response);
response.setContentType("text/plain; charset=UTF-8");
PrintWriter out =response.getWriter();
Enumeration
while(nameList.hasMoreElements()) {
String name = nameList.nextElement();
String[] value = request.getParameterValues(name);
for(int i=0; i
}
}
}
}
VariousForm.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%--JSPコメント POSTメソッドで送信 --%>
<form action="../ServletVariousForm" method="post">
テキストボックス<br>
<input type="text" name="message"><br>
テキストエリア<br>
<textarea rows="3" cols="20" name="textarea">テキストエリアデフォルト</textarea><br>
ラジオボタン<br>
<input type="radio" name="radio" value="radio1">男
<input type="radio" name="radio" value="radio2">女<br>
チェックボックス<br>
<input type="checkbox" name="check1" >テレビ
<input type="checkbox" name="check2" >音楽
<input type="checkbox" name="check3" >スポーツ<br>
セレクト<br>
<select name="select" size="3" multiple=true>
<option value="sel1">お寿司
<option value="sel2">焼肉
<option value="sel3">ハンバーグ
</select><br>
<input type="hidden" name="hidden" value="隠し項目">
<input type="submit" value="フォームでpost送信">
<input type="reset">
</form>
</body>
</html>
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%--JSPコメント POSTメソッドで送信 --%>
<form action="../ServletVariousForm" method="post">
テキストボックス<br>
<input type="text" name="message"><br>
テキストエリア<br>
<textarea rows="3" cols="20" name="textarea">テキストエリアデフォルト</textarea><br>
ラジオボタン<br>
<input type="radio" name="radio" value="radio1">男
<input type="radio" name="radio" value="radio2">女<br>
チェックボックス<br>
<input type="checkbox" name="check1" >テレビ
<input type="checkbox" name="check2" >音楽
<input type="checkbox" name="check3" >スポーツ<br>
セレクト<br>
<select name="select" size="3" multiple=true>
<option value="sel1">お寿司
<option value="sel2">焼肉
<option value="sel3">ハンバーグ
</select><br>
<input type="hidden" name="hidden" value="隠し項目">
<input type="submit" value="フォームでpost送信">
<input type="reset">
</form>
</body>
</html>