これまでは、Spring Bootの画面にThymeleafを利用していたが、今回はJSPを利用してみたので、そのサンプルプログラムを共有する。
Thymeleafで実装していた内容と同じ機能を、JSTLタグを利用したJSPによって実装できる。なお、JSTLタグとは、JSPで利用される標準的なカスタムタグをまとめたものをいう。
前提条件
下記記事の実装が完了していること
サンプルプログラムの内容
今回のサンプルプログラムの構成は以下の通り。
なお、上記赤枠のうち、「buid.gradle」「application.yml」が変更したプログラムで、他は新規追加したプログラムである。
build.gradleの内容は以下の通りで、thymeleafの設定を削除し、JSPの設定を追加している。
plugins { id 'org.springframework.boot' version '2.1.7.RELEASE' id 'java' } apply plugin: 'io.spring.dependency-management' group = 'com.example' version = '0.0.1-SNAPSHOT' sourceCompatibility = '1.8' repositories { mavenCentral() } configurations { //log4j2を利用するため、Spring BootデフォルトのLogbackを利用しないよう設定 all*.exclude module : 'spring-boot-starter-logging' } dependencies { implementation 'org.springframework.boot:spring-boot-starter-web' testImplementation 'org.springframework.boot:spring-boot-starter-test' compileOnly 'org.projectlombok:lombok:1.18.10' annotationProcessor 'org.projectlombok:lombok:1.18.10' compile files('lib/ojdbc6.jar') implementation 'org.mybatis.spring.boot:mybatis-spring-boot-starter:2.1.1' compile group: 'org.springframework.data', name: 'spring-data-commons-core', version: '1.1.0.RELEASE' //log4j2を利用するための設定 compile group: 'org.apache.logging.log4j', name: 'log4j-api', version: '2.12.1' compile group: 'org.apache.logging.log4j', name: 'log4j-core', version: '2.12.1' //AOPを利用するための設定 implementation 'org.springframework.boot:spring-boot-starter-aop' //log4j2の設定でymlファイルを利用するための設定 compile group: 'com.fasterxml.jackson.dataformat', name: 'jackson-dataformat-yaml', version: '2.10.1' compile group: 'com.fasterxml.jackson.core', name: 'jackson-core', version: '2.10.1' compile group: 'com.fasterxml.jackson.core', name: 'jackson-databind', version: '2.10.1' //Apache Common JEXLを利用するための設定 compile group: 'org.apache.commons', name: 'commons-jexl3', version: '3.0' //thymeleafの設定を削除 //implementation 'org.springframework.boot:spring-boot-starter-thymeleaf' //JSPを利用するための設定を追加 compile group: 'org.apache.tomcat.embed', name: 'tomcat-embed-jasper', version: '9.0.30' compile group: 'javax.servlet', name: 'jstl', version: '1.2' }
また、application.ymlの内容は以下の通りで、JSPを利用するための設定を追加している。
server: port: 8084 # DB接続情報 spring: datasource: url: jdbc:oracle:thin:@localhost:1521:xe username: USER01 password: USER01 driverClassName: oracle.jdbc.driver.OracleDriver # JSPを利用する設定 mvc: view: prefix: /WEB-INF/views/ suffix: .jsp # 一覧画面で1ページに表示する行数 demo: list: pageSize: 2
さらに、demo.cssの内容は以下の通りで、前提条件のプログラムと同じ内容であるが、配置場所をwebapp/static下に変更している。
.errorMessage{ color: #FF0000; } .fieldError{ background-color: #FFCCFF; }
また、JSPファイルの内容は以下の通りで、前提条件のプログラム「xxx.html」を「xxx.jsp」にそれぞれ変更し、JSTLタグを利用したJSPの内容に変更している。さらに、配置場所をwebapp/WEB-INF/views下(application.ymlのspring.mvc.view.prefixで指定した場所)に変更している。
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %> <!DOCTYPE html> <html> <head> <link rel="stylesheet" type="text/css" href="/static/demo.css" /> <title>index page</title> </head> <p>検索条件を指定し、「検索」ボタンを押下してください。</p><br/> <form:form method="post" action="/search" modelAttribute="searchForm"> <form:errors path="fromBirthYear" cssClass="errorMessage" /> <form:errors path="toBirthYear" cssClass="errorMessage" /> <table border="1" cellpadding="5"> <tr> <th>名前</th> <td><form:input path="searchName" /></td> </tr> <tr> <th>生年月日</th> <td> <form:input path="fromBirthYear" size="4" maxlength="4" cssErrorClass="fieldError" />年 <form:select path="fromBirthMonth" cssErrorClass="fieldError"> <form:option value="" label=""/> <form:options items="${searchForm.getMonthItems()}" /> </form:select>月 <form:select path="fromBirthDay" cssErrorClass="fieldError"> <form:option value="" label=""/> <form:options items="${searchForm.getDayItems()}" /> </form:select>日~ <form:input path="toBirthYear" size="4" maxlength="4" cssErrorClass="fieldError" />年 <form:select path="toBirthMonth" cssErrorClass="fieldError"> <form:option value="" label=""/> <form:options items="${searchForm.getMonthItems()}" /> </form:select>月 <form:select path="toBirthDay" cssErrorClass="fieldError"> <form:option value="" label=""/> <form:options items="${searchForm.getDayItems()}" /> </form:select>日 </td> </tr> <tr> <th>性別</th> <td> <form:select path="searchSex"> <form:option value="" label=""/> <form:options items="${searchForm.getSexItems()}" /> </form:select> </td> </tr> </table> <br/><br/> <input type="submit" value="検索" /> <input type="button" value="閉じる" onclick="window.close();" /> </form:form> </body> </html>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <!DOCTYPE html> <html> <head> <title>index page</title> </head> <body> ユーザーデータテーブル(user_data)の全データ<br/><br/> <table border="1" cellpadding="5"> <tr> <th>ID</th> <th>名前</th> <th>生年月日</th> <th>性別</th> <th></th> <th></th> </tr> <c:forEach var="obj" items="${demoFormList}"> <tr> <td><c:out value="${obj.id}" /></td> <td><c:out value="${obj.name}" /></td> <td> <c:out value="${obj.birthYear}年 ${obj.birthMonth}月 ${obj.birthDay}日" /> </td> <td><c:out value="${obj.sex_value}" /></td> <td><a href="/update?id=${obj.id}">更新</a></td> <td><a href="/delete_confirm?id=${obj.id}">削除</a></td> </tr> </c:forEach> </table> <br/><br/> <table border="0"> <tr> <td width="70"> <c:if test="${currentPageNum != 1}" > <a href="/firstPage">先頭へ</a> </c:if> </td> <td width="50"> <c:if test="${currentPageNum != 1}" > <a href="/backPage">前へ</a> </c:if> </td> <td width="50"> <c:out value="${currentPageNum}" /> / <c:out value="${allPageNum}" /> </td> <td width="50"> <c:if test="${currentPageNum != allPageNum}" > <a href="/nextPage">次へ</a> </c:if> </td> <td width="70"> <c:if test="${currentPageNum != allPageNum}" > <a href="/lastPage">最後へ</a> </c:if> </td> </tr> </table> <br/><br/> <form:form method="post" action="/add" modelAttribute="demoForm"> <input type="submit" name="next" value="データ追加" /><br/><br/> <input type="submit" name="back" value="戻る" /> </form:form> </body> </html>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <!DOCTYPE html> <html> <head> <link rel="stylesheet" type="text/css" href="/static/demo.css" /> <title>入力画面</title> </head> <body> <p>下記必要事項を記載の上、「確認」ボタンを押下してください。</p><br/> <form:form method="post" action="/confirm" modelAttribute="demoForm"> <table border="0"> <tr> <td align="left" valign="top">名前:</td> <td> <form:input path="name" cssErrorClass="fieldError" /> <form:errors path="name" cssClass="errorMessage" /> </td> </tr> <tr> <td align="left" valign="top">生年月日:</td> <td> <form:input path="birthYear" size="4" maxlength="4" cssErrorClass="fieldError" />年 <form:select path="birthMonth" cssErrorClass="fieldError"> <form:option value="" label=""/> <form:options items="${demoForm.getMonthItems()}" /> </form:select>月 <form:select path="birthDay" cssErrorClass="fieldError"> <form:option value="" label=""/> <form:options items="${demoForm.getDayItems()}" /> </form:select>日 <form:errors path="birthYear" cssClass="errorMessage" /> <form:errors path="birthMonth" cssClass="errorMessage" /> <form:errors path="birthDay" cssClass="errorMessage" /> </td> </tr> <tr> <td align="left" valign="top">性別:</td> <td> <c:forEach var="item" items="${demoForm.getSexItems()}"> <form:radiobutton path="sex" value="${item.key}" cssErrorClass="fieldError" /> ${item.value} </c:forEach> <form:errors path="sex" cssClass="errorMessage" /> </td> </tr> <tr> <td align="left" valign="top">メモ:</td> <td> <form:textarea path="memo" rows="6" cols="40" /> </td> </tr> <tr> <td align="left" valign="top">入力確認:</td> <td> <form:checkbox path="checked" value="確認済" cssErrorClass="fieldError" /> <form:errors path="checked" cssClass="errorMessage" /> </td> </tr> </table> <br/><br/> <input type="submit" name="next" value="確認" /> <input type="submit" name="back" value="戻る" /> </form:form> </body> </html>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %> <!DOCTYPE html> <html> <head> <title>確認画面</title> </head> <body> <p>入力内容を確認し、問題なければ「送信」ボタンを押下してください。</p><br/> <form:form method="post" action="/send" modelAttribute="demoForm"> <table border="0"> <tr> <td align="left" valign="top">名前:</td> <td> <c:out value="${demoForm.name}" /> </td> </tr> <tr> <td align="left" valign="top">生年月日:</td> <td> <c:out value="${demoForm.birthYear}" />年 <c:forEach var="obj" items="${demoForm.getMonthItems()}"> <c:if test="${obj.key == demoForm.birthMonth}"> <c:out value="${obj.value}" />月 </c:if> </c:forEach> <c:forEach var="obj" items="${demoForm.getDayItems()}"> <c:if test="${obj.key == demoForm.birthDay}"> <c:out value="${obj.value}" />日 </c:if> </c:forEach> </td> </tr> <tr> <td align="left" valign="top">性別:</td> <td> <c:forEach var="obj" items="${demoForm.getSexItems()}"> <c:if test="${obj.key == demoForm.sex}"> <c:out value="${obj.value}" /> </c:if> </c:forEach> </td> </tr> <tr> <td align="left" valign="top">メモ:</td> <td> <% pageContext.setAttribute("newLineChar", "\n"); %> <c:forEach var="memoStr" varStatus="memoStat" items="${fn:split(demoForm.memo, newLineChar)}"> <c:out value="${memoStr}" /> <c:if test="${memoStat.last != true}"> <br/> </c:if> </c:forEach> </td> </tr> <tr> <td align="left" valign="top">入力確認:</td> <td> <c:out value="${demoForm.checked}" /> </td> </tr> </table> <br/><br/> <input type="submit" name="next" value="確認" /> <input type="submit" name="back" value="戻る" /> </form:form> </body> </html>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %> <!DOCTYPE html> <html> <head> <title>完了画面</title> </head> <body> お申し込みが完了しました。<br/><br/> <form:form method="post" action="/"> <input type="submit" value="検索画面に戻る" /> </form:form> </body> </html>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %> <!DOCTYPE html> <html> <head> <title>削除確認画面</title> </head> <body> <p>下記内容を削除してよろしいでしょうか?問題なければ「送信」ボタンを押下してください。</p> <form:form method="post" action="/delete" modelAttribute="demoForm"> <table border="0"> <tr> <td align="left" valign="top">名前:</td> <td> <c:out value="${demoForm.name}" /> </td> </tr> <tr> <td align="left" valign="top">生年月日:</td> <td> <c:out value="${demoForm.birthYear}" />年 <c:forEach var="obj" items="${demoForm.getMonthItems()}"> <c:if test="${obj.key == demoForm.birthMonth}"> <c:out value="${obj.value}" />月 </c:if> </c:forEach> <c:forEach var="obj" items="${demoForm.getDayItems()}"> <c:if test="${obj.key == demoForm.birthDay}"> <c:out value="${obj.value}" />日 </c:if> </c:forEach> </td> </tr> <tr> <td align="left" valign="top">性別:</td> <td> <c:forEach var="obj" items="${demoForm.getSexItems()}"> <c:if test="${obj.key == demoForm.sex}"> <c:out value="${obj.value}" /> </c:if> </c:forEach> </td> </tr> <tr> <td align="left" valign="top">メモ:</td> <td> <% pageContext.setAttribute("newLineChar", "\n"); %> <c:forEach var="memoStr" varStatus="memoStat" items="${fn:split(demoForm.memo, newLineChar)}"> <c:out value="${memoStr}" /> <c:if test="${memoStat.last != true}"> <br/> </c:if> </c:forEach> </td> </tr> </table> <br/><br/> <input type="submit" name="next" value="確認" /> <input type="submit" name="back" value="戻る" /> </form:form> </body> </html>
なお、本JSPで使用しているJSTLのcoreタグについては、以下のサイトを参照のこと。
http://struts.wasureppoi.com/jstl/02_core.html
その他のソースコード内容は、以下のサイトを参照のこと。
https://github.com/purin-it/java/tree/master/spring-boot-jsp/demo
サンプルプログラムの実行結果
下記記事の「サンプルプログラムの実行結果」と同等の実行結果となる。
要点まとめ
- Thymeleafで実装していた内容と同じ機能を、JSTLタグを利用したJSPによって実装することができる。