Webアプリケーション向け開発プロジェクトの作成
================================================================================

.. only:: html

.. contents:: 目次
  :depth: 3
  :local:

本節では、Webアプリケーション向けの開発プロジェクトを作成する方法について説明する。

本ガイドラインでは、マルチプロジェクト構成を採用することを推奨している。推奨するマルチプロジェクト構成の説明については、「\ :ref:`application-layering_project-structure`\ 」を参照されたい。

|

.. _CreateProjectFromBlankTypes:

ブランクプロジェクトの種類
--------------------------------------------------------------------------------

ブランクプロジェクトは、使用用途に応じて以下の2種類を提供している。

.. tabularcolumns:: |p{0.20\linewidth}|p{0.80\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 20 70

  * - 種別
    - 使用用途
  * - | \ `マルチプロジェクト構成のブランクプロジェクト <https://github.com/Macchinetta/macchinetta-web-multi-blank-thymeleaf/tree/1.11.0.RELEASE>`_\
    - 商用環境にリリースするような本格的なアプリケーションを開発する際に使用する。

      プロジェクトの雛形は、MavenのArchetypeとして以下を用意している。

      * MyBatis3用の設定が盛り込まれた雛形

      \ **本ガイドラインでは、マルチプロジェクト構成のプロジェクトを使用する事を推奨している。**\
  * - | \ `シングルプロジェクト構成のブランクプロジェクト <https://github.com/Macchinetta/macchinetta-web-blank-thymeleaf/tree/1.11.0.RELEASE>`_\
    - POC(Proof Of Concept)、プロトタイプ、サンプルなどの簡易的なアプリケーションを作成する際に使用する。

      プロジェクトの雛形は、MavenのArchetypeとして以下を用意している。

      * MyBatis3用の設定が盛り込まれた雛形
      * O/R Mapperに依存しない雛形

      本ガイドラインでは、各種チュートリアルについてシングルプロジェクトを使用して行う手順となっている。

|

.. _CreateWebApplicationProject:

開発プロジェクトの作成
--------------------------------------------------------------------------------

マルチプロジェクト構成の開発プロジェクトを、
\ `Maven Archetype Plugin <https://maven.apache.org/archetype/maven-archetype-plugin/>`_\ の\ `archetype:generate <https://maven.apache.org/archetype/maven-archetype-plugin/generate-mojo.html>`_\ を使用して作成する。

.. note:: \ **前提条件**\

  以降の説明では、

  * \ `Maven <https://maven.apache.org/>`_\ (\ ``mvn``\ コマンド)が使用可能であること
  * インターネットに繋がっていること
  * インターネットにプロキシ経由で繋ぐ場合は、\ `Mavenのプロキシ設定 <https://maven.apache.org/guides/mini/guide-proxies.html>`_\ が行われていること

  を前提としている。

  前提条件が整っていない場合は、まずこれらのセットアップを行ってほしい。

|

マルチプロジェクトを作成するためのArchetypeとして、以下を用意している。

.. tabs::
  .. group-tab:: Java Config

    .. tabs::
      .. group-tab:: JSP
    
        .. tabularcolumns:: |p{0.05\linewidth}|p{0.30\linewidth}|p{0.65\linewidth}|
        .. list-table::
          :header-rows: 1
          :widths: 5 30 65
        
          * - 項番
            - Archetype(ArtifactId)
            - 説明
          * - 1.
            - macchinetta-multi-web-blank-jsp-mybatis3-archetype
            - O/R MapperとしてMyBatis3を使用するためのプロジェクトを生成するためのArchetype。
    
      .. group-tab:: Thymeleaf
    
        .. tabularcolumns:: |p{0.05\linewidth}|p{0.30\linewidth}|p{0.65\linewidth}|
        .. list-table::
          :header-rows: 1
          :widths: 5 30 65
        
          * - 項番
            - Archetype(ArtifactId)
            - 説明
          * - 1.
            - macchinetta-multi-web-blank-thymeleaf-mybatis3-archetype
            - O/R MapperとしてMyBatis3を使用するためのプロジェクトを生成するためのArchetype。

  .. group-tab:: XML Config

    .. tabs::
      .. group-tab:: JSP
    
        .. tabularcolumns:: |p{0.05\linewidth}|p{0.30\linewidth}|p{0.65\linewidth}|
        .. list-table::
          :header-rows: 1
          :widths: 5 30 65
        
          * - 項番
            - Archetype(ArtifactId)
            - 説明
          * - 1.
            - macchinetta-multi-web-blank-xmlconfig-jsp-mybatis3-archetype
            - O/R MapperとしてMyBatis3を使用するためのプロジェクトを生成するためのArchetype。
    
      .. group-tab:: Thymeleaf
    
        .. tabularcolumns:: |p{0.05\linewidth}|p{0.30\linewidth}|p{0.65\linewidth}|
        .. list-table::
          :header-rows: 1
          :widths: 5 30 65
        
          * - 項番
            - Archetype(ArtifactId)
            - 説明
          * - 1.
            - macchinetta-multi-web-blank-xmlconfig-thymeleaf-mybatis3-archetype
            - O/R MapperとしてMyBatis3を使用するためのプロジェクトを生成するためのArchetype。

|

プロジェクトを作成するフォルダに移動する。

.. code-block:: console

    cd C:\work

|

\ `Maven Archetype Plugin <https://maven.apache.org/archetype/maven-archetype-plugin/>`_\ の\ `archetype:generate <https://maven.apache.org/archetype/maven-archetype-plugin/generate-mojo.html>`_\ を使用して、プロジェクトを作成する。

.. code-block:: console

  mvn archetype:generate -B^
   -DarchetypeGroupId=com.github.macchinetta.blank^
   -DarchetypeArtifactId=macchinetta-multi-web-blank-jsp-mybatis3-archetype^
   -DarchetypeVersion=1.11.0.RELEASE^
   -DgroupId=com.example.todo^
   -DartifactId=todo^
   -Dversion=1.0.0-SNAPSHOT

.. tabularcolumns:: |p{0.25\linewidth}|p{0.75\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 25 75

  * - パラメータ
    - 説明
  * - | \-B
    - batch mode (対話を省略)
  * - | \-DarchetypeGroupId
    - ブランクプロジェクトのgroupIdを指定する。(固定)
  * - | \-DarchetypeArtifactId
    - ブランクプロジェクトのarchetypeId(雛形を特定するためのID)を指定する。\ **(カスタマイズが必要)**\

      以下の何れかのarchetypeIdを指定する。

      * \ ``macchinetta-multi-web-blank-jsp-mybatis3-archetype``\
      * \ ``macchinetta-multi-web-blank-thymeleaf-mybatis3-archetype``\
      * \ ``macchinetta-multi-web-blank-xmlconfig-jsp-mybatis3-archetype``\
      * \ ``macchinetta-multi-web-blank-xmlconfig-thymeleaf-mybatis3-archetype``\

      上記例では、\ ``macchinetta-multi-web-blank-jsp-mybatis3-archetype``\ を指定している。
  * - | \-DarchetypeVersion
    - ブランクプロジェクトのバージョンを指定する。(固定)
  * - | \-DgroupId
    - 作成するプロジェクトのgroupIdを指定する。\ **(カスタマイズが必要)**\

      上記例では、\ ``com.example.todo``\ を指定している。
  * - | \-DartifactId
    - 作成するプロジェクトのartifactIdを指定する。\ **(カスタマイズが必要)**\

      上記例では、\ ``todo``\ を指定している。
  * - | \-Dversion
    - 作成するプロジェクトのバージョンを指定する。\ **(カスタマイズが必要)**\

      上記例では、\ ``1.0.0-SNAPSHOT``\ を指定している。

|

| プロジェクトの作成が成功した場合、以下のようなログが出力される。
| (以下は、MyBatis3用(JavaConfig, JSP)のArchetypeを使用して作成した場合の出力例)

.. code-block:: console

  (omitted)
  [INFO] ----------------------------------------------------------------------------
  [INFO] Using following parameters for creating project from Archetype: macchinetta-multi-web-blank-jsp-mybatis3-archetype:1.11.0.RELEASE
  [INFO] ----------------------------------------------------------------------------
  [INFO] Parameter: groupId, Value: com.example.todo
  [INFO] Parameter: artifactId, Value: todo
  [INFO] Parameter: version, Value: 1.0.0-SNAPSHOT
  [INFO] Parameter: package, Value: com.example.todo
  [INFO] Parameter: packageInPathFormat, Value: com/example/todo
  [INFO] Parameter: package, Value: com.example.todo
  [INFO] Parameter: ProjectName, Value: Todo
  [INFO] Parameter: groupId, Value: com.example.todo
  [INFO] Parameter: artifactId, Value: todo
  [INFO] Parameter: version, Value: 1.0.0-SNAPSHOT
  [INFO] Parent element not overwritten in C:\work\Git\home\tmp\todo\todo-env\pom.xml
  [INFO] Parent element not overwritten in C:\work\Git\home\tmp\todo\todo-domain\pom.xml
  [INFO] Parent element not overwritten in C:\work\Git\home\tmp\todo\todo-web\pom.xml
  [INFO] Parent element not overwritten in C:\work\Git\home\tmp\todo\todo-initdb\pom.xml
  [INFO] Parent element not overwritten in C:\work\Git\home\tmp\todo\todo-selenium\pom.xml
  [INFO] Project created from Archetype in dir: C:\work\Git\home\tmp\todo
  [INFO] ------------------------------------------------------------------------
  [INFO] BUILD SUCCESS
  [INFO] ------------------------------------------------------------------------
  [INFO] Total time:  9.303 s
  [INFO] Finished at: 2023-07-10T18:06:30+09:00
  [INFO] ------------------------------------------------------------------------

|

| プロジェクトの作成が成功した場合、Mavenのマルチプロジェクトが作成される。
| Maven Archetypeで作成したプロジェクトの詳細な説明については、「\ :ref:`CreateWebApplicationProjectConfiguration`\ 」を参照されたい。

.. code-block:: console

  todo
  ├── pom.xml
  ├── todo-domain
  ├── todo-env
  ├── todo-initdb
  ├── todo-selenium
  └── todo-web

|

.. _CreateWebApplicationProjectCustomize:

開発プロジェクトのカスタマイズ
--------------------------------------------------------------------------------

Maven Archetypeで作成したプロジェクトには、アプリケーション毎にカスタマイズが必要な箇所がいくつか存在する。

カスタマイズが必要な箇所を以下に示す。

- \ :ref:`CreateWebApplicationProjectCustomizeProjectInformation`\
- \ :ref:`CreateWebApplicationProjectCustomizeMessageId`\
- \ :ref:`CreateWebApplicationProjectCustomizeMessageWording`\
- \ :ref:`CreateWebApplicationProjectCustomizeErrorScreen`\
- \ :ref:`CreateWebApplicationProjectCustomizeInMemoryDatabase`\
- \ :ref:`CreateWebApplicationProjectCustomizeDataSource`\

.. note::

  上記以外のカスタマイズポイントとしては、

  * \ :doc:`../Security/Authentication`\ ・\ :doc:`../Security/Authorization`\ の設定
  * \ :doc:`../ArchitectureInDetail/WebApplicationDetail/FileUpload`\ を有効化するための設定
  * \ :doc:`../ArchitectureInDetail/WebApplicationDetail/Internationalization`\ を有効化するための設定
  * \ :doc:`../ArchitectureInDetail/GeneralFuncDetail/Logging`\ の定義
  * \ :doc:`../ArchitectureInDetail/WebApplicationDetail/ExceptionHandling`\ の定義
  * \ :doc:`../ArchitectureInDetail/WebServiceDetail/REST`\ 向けの設定の適用

  などがある。

  これらのカスタマイズについては、各節のHow to useを参照し、必要に応じてカスタマイズしてほしい。

.. note::

  以降の説明で\ ``[artifactId]``\ と表現している部分は、プロジェクト作成時に指定した\ ``artifactId``\ に置き換えて読み進めてほしい。

|

.. _CreateWebApplicationProjectCustomizeProjectInformation:

POMファイル
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

プロジェクト情報
""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""

Maven Archetypeで作成したプロジェクトのPOMファイルでは、

* プロジェクト名(\ ``name``\ 要素)
* プロジェクト説明(\ ``description``\ 要素)
* プロジェクトURL(\ ``url``\ 要素)
* プロジェクト創設年(\ ``inceptionYear``\ 要素)
* プロジェクトライセンス(\ ``licenses``\ 要素)
* プロジェクト組織(\ ``organization``\ 要素)
* 開発者(\ ``developers``\ 要素)
* ソース管理システム(\ ``scm``\ 要素)

| といったプロジェクト情報が、Archetype自身のプロジェクト情報が設定されている状態となっている。
| 例として、ブランクプロジェクトで設定している内容を以下に示す。
| \ **プロジェクト情報には、適切な値を設定すること。**\

.. code-block:: xml

  <!-- omitted -->

  <name>Macchinetta Server Framework (1.x) Web Blank Multi Project (JavaConfig)(JSP)(MyBatis3)</name>
  <description>Web Blank Multi Project (JavaConfig)(JSP)(MyBatis3) using Macchinetta Server Framework (1.x)</description>
  <url>http://macchinetta.github.io</url>
  <inceptionYear>2017</inceptionYear>
  <licenses>
      <license>
          <name>Apache License, Version 2.0</name>
          <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
          <distribution>manual</distribution>
      </license>
  </licenses>
  <organization>
      <name>Macchinetta Framework Team</name>
      <url>http://macchinetta.github.io</url>
  </organization>
  <developers>
      <developer>
          <name>Macchinetta</name>
          <organization>Macchinetta</organization>
          <organizationUrl>http://macchinetta.github.io</organizationUrl>
      </developer>
  </developers>
  <scm>
      <connection>scm:git:git://github.com/Macchinetta/macchinetta-web-multi-blank.git</connection>
      <developerConnection>scm:git:ssh://github.com/Macchinetta/macchinetta-web-multi-blank.git</developerConnection>
      <url>https://github.com/Macchinetta/macchinetta-web-multi-blank</url>
  </scm>

  <!-- omitted -->

.. tip::

  JDK17を使用してマルチプロジェクトのarchetypeを生成すると、親POMに余分な空行が追加されることを確認している。

  動作に影響はないため、適宜空白行を削除して使用されたい。

|

カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。

.. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 45 45

  * - 項番
    - 対象ファイル
    - カスタマイズ方法
  * - 1.
    - マルチプロジェクト全体の構成を定義するPOM(Project Object Model)ファイル

      \ ``[artifactId]/pom.xml``\
    - プロジェクト情報に適切な値を指定する。

|

.. _CreateWebApplicationProjectMavenCompilerPlugin:

maven-compiler-plugin
""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""

Maven Archetypeで作成したプロジェクトのPOMファイルでは、以下の様にmaven-compiler-pluginが設定されている。

.. code-block:: xml

  <!-- omitted -->

  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <configuration>
      <!-- (1) -->
      <parameters>true</parameters>
      <annotationProcessorPaths>
        <path>
          <!-- (2) -->
          <groupId>org.mapstruct</groupId>
          <artifactId>mapstruct-processor</artifactId>
          <version>${mapstruct.version}</version>
        </path>
        <!-- (3) -->
        <!-- REMOVE THIS LINE IF YOU USE MapStruct AND Lombok
        <path>
          <groupId>org.projectlombok</groupId>
          <artifactId>lombok</artifactId>
          <version>${lombok.version}</version>
        </path> 
        <path>
          <groupId>org.projectlombok</groupId>
          <artifactId>lombok-mapstruct-binding</artifactId>
          <version>${lombok-mapstruct-binding.version}</version>
        </path>
        REMOVE THIS LINE IF YOU USE MapStruct AND Lombok -->
      </annotationProcessorPaths>
      <compilerArgs>
        <!-- (2) -->
        <arg>-Amapstruct.defaultComponentModel=spring</arg>
      </compilerArgs>
    </configuration>
  </plugin>

\ ``configuration``\ については以下の通り

.. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 45

  * - 項番
    - 概要
  * - 1.
    - | Java8から追加された\ ``-parameters``\ オプション(メソッド・パラメータにリフレクション用のメタデータを生成するモード)
      | Spring の各機能は\ ``-parameters``\ が設定されていることを前提としており、\ ``-parameters``\ を設定していない場合、\ ``@RequestParam``\ や\ ``@PathVariable``\ の属性省略ができなくなる、XMLConfigでBean定義する際に変数を名前で解決することができなくなる等の問題が発生する。
  * - 2.
    - MapStructを使用するための設定。詳しくは\ :ref:`mapstruct-setting`\ を参照されたい。
  * - 3.
    - MapStructとLombokを併用するための設定。詳しくは\ :ref:`mapstruct_lombok`\ を参照されたい。

|

.. _CreateWebApplicationProjectCustomizeMessageId:

x.xx.fw.9999形式のメッセージID
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Maven Archetypeで作成したプロジェクトでは、\ ``x.xx.fw.9999``\ 形式のメッセージIDを、

* エラー画面に表示するメッセージ
* 例外発生時に出力するエラーログ

を生成する際に使用している。実際の使用箇所(サンプリング)を以下に示す。

\ **[application-messages.properties]**\

.. code-block:: properties

  e.xx.fw.5001 = Resource not found.

.. tabs::
  .. group-tab:: JSP

    \ **[JSP]**\

    .. code-block:: jsp
    
      <div class="error">
          <c:if test="${!empty exceptionCode}">[${f:h(exceptionCode)}]</c:if>
          <spring:message code="e.xx.fw.5001" />
      </div>

  .. group-tab:: Thymeleaf

    \ **[HTML]**\
    
    .. code-block:: html
    
      <div class="error">
          <span th:text="${#strings.isEmpty(exceptionCode)} ? #{e.xx.fw.5001} : |[${exceptionCode}] #{e.xx.fw.5001}|">[e.xx.fw.5001]
              Resource not found.</span>
      </div>

\ **[applicationContext.xml]**\

.. code-block:: xml

  <bean id="exceptionCodeResolver"
      class="org.terasoluna.gfw.common.exception.SimpleMappingExceptionCodeResolver">
      <!-- omitted -->
              <entry key="ResourceNotFoundException" value="e.xx.fw.5001" />
      <!-- omitted -->
  </bean>

|

\ ``x.xx.fw.9999``\ 形式のメッセージIDは、本ガイドラインの「\ :doc:`../ArchitectureInDetail/WebApplicationDetail/MessageManagement`\ 」で紹介しているメッセージID体系であるが、プロジェクト区分の値が暫定値「\ ``xx``\ 」の状態になっている。

.. note::

  * \ **本ガイドラインで紹介しているメッセージID体系を利用する場合は、プロジェクト区分に適切な値を指定すること。**\ 本ガイドラインで紹介しているメッセージID体系については、「\ :ref:`message-management_result-rule`\ 」を参照されたい。
  * 本ガイドラインで紹介しているメッセージID体系を利用しない場合は、以下に示す修正対象ファイル内で使用しているメッセージIDを全て置き換える必要がある。

|

カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。

.. tabs::
  .. group-tab:: Java Config

    .. tabs::
      .. group-tab:: JSP
    
        .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
        .. list-table::
          :header-rows: 1
          :widths: 10 45 45
        
          * - 項番
            - 対象ファイル
            - カスタマイズ方法
          * - 1.
            - メッセージ定義ファイル
        
              \ ``[artifactId]/[artifactId]-web/src/main/resources/i18n/application-messages.properties``\
            - プロパティキーに指定しているメッセージIDのプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
          * - 2.
            - エラー画面用のJSP
        
              \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/common/error/*.jsp``\
            - \ ``<spring:message>``\ 要素の\ ``code``\ 属性に指定しているメッセージIDのプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
          * - 3.
            - Webアプリケーション用のアプリケーションコンテキストを作成するためのBean定義ファイル
        
              \ ``[artifactId]/[artifactId]-web/src/main/java/com/example/todo/config/app/ApplicationContextConfig.java``\
            - BeanIDが\ ``exceptionCodeResolver``\ のBean定義内で指定している例外コード(メッセージID)のプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
    
      .. group-tab:: Thymeleaf
    
        .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
        .. list-table::
          :header-rows: 1
          :widths: 10 45 45
        
          * - 項番
            - 対象ファイル
            - カスタマイズ方法
          * - 1.
            - メッセージ定義ファイル
        
              \ ``[artifactId]/[artifactId]-web/src/main/resources/i18n/application-messages.properties``\
            - プロパティキーに指定しているメッセージIDのプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
          * - 2.
            - エラー画面用のThymeleafのテンプレートHTML
        
              \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/common/error/*.html(unhandledSystemError.htmlを除く)``\
            - \ ``<div>``\ 要素の\ ``th:text``\ 属性に指定しているメッセージIDのプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
          * - 3.
            - Webアプリケーション用のアプリケーションコンテキストを作成するためのBean定義ファイル
        
              \ ``[artifactId]/[artifactId]-web/src/main/java/com/example/todo/config/app/ApplicationContextConfig.java``\
            - BeanIDが\ ``exceptionCodeResolver``\ のBean定義内で指定している例外コード(メッセージID)のプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。

  .. group-tab:: XML Config

    .. tabs::
      .. group-tab:: JSP
    
        .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
        .. list-table::
          :header-rows: 1
          :widths: 10 45 45
        
          * - 項番
            - 対象ファイル
            - カスタマイズ方法
          * - 1.
            - メッセージ定義ファイル
        
              \ ``[artifactId]/[artifactId]-web/src/main/resources/i18n/application-messages.properties``\
            - プロパティキーに指定しているメッセージIDのプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
          * - 2.
            - エラー画面用のJSP
        
              \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/common/error/*.jsp``\
            - \ ``<spring:message>``\ 要素の\ ``code``\ 属性に指定しているメッセージIDのプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
          * - 3.
            - Webアプリケーション用のアプリケーションコンテキストを作成するためのBean定義ファイル
        
              \ ``[artifactId]/[artifactId]-web/src/main/resources/META-INF/spring/applicationContext.xml``\
            - BeanIDが\ ``exceptionCodeResolver``\ のBean定義内で指定している例外コード(メッセージID)のプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
    
      .. group-tab:: Thymeleaf
    
        .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
        .. list-table::
          :header-rows: 1
          :widths: 10 45 45
        
          * - 項番
            - 対象ファイル
            - カスタマイズ方法
          * - 1.
            - メッセージ定義ファイル
        
              \ ``[artifactId]/[artifactId]-web/src/main/resources/i18n/application-messages.properties``\
            - プロパティキーに指定しているメッセージIDのプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
          * - 2.
            - エラー画面用のThymeleafのテンプレートHTML
        
              \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/common/error/*.html(unhandledSystemError.htmlを除く)``\
            - \ ``<div>``\ 要素の\ ``th:text``\ 属性に指定しているメッセージIDのプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。
          * - 3.
            - Webアプリケーション用のアプリケーションコンテキストを作成するためのBean定義ファイル
        
              \ ``[artifactId]/[artifactId]-web/src/main/resources/META-INF/spring/applicationContext.xml``\
            - BeanIDが\ ``exceptionCodeResolver``\ のBean定義内で指定している例外コード(メッセージID)のプロジェクト区分の暫定値「\ ``xx``\ 」を、適切な値に修正する。

|

.. _CreateWebApplicationProjectCustomizeMessageWording:

メッセージ文言
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

| Maven Archetypeで作成したプロジェクトでは、いくつかのメッセージ定義を提供しているが、メッセージ文言は簡易的なメッセージになっている。
| 例として、ブランクプロジェクトのメッセージ(サンプリング)を以下に示す。
| \ **アプリケーション要件(メッセージ規約など)に合わせて修正すること。**\

\ **[application-messages.properties]**\

.. code-block:: properties

  e.xx.fw.5001 = Resource not found.

  # omitted

  # typemismatch
  typeMismatch="{0}" is invalid.

  # omitted

|

カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。

.. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 45 45

  * - 項番
    - 対象ファイル
    - カスタマイズ方法
  * - 1.
    - メッセージ定義ファイル

      \ ``[artifactId]/[artifactId]-web/src/main/resources/i18n/application-messages.properties``\
    - アプリケーション要件に応じたメッセージに修正する。

      | 入力チェックでエラーとなった際に表示するメッセージ(Bean Validationのメッセージ)についても、アプリケーション要件に応じて修正(デフォルトメッセージの上書き)が必要になる。
      | デフォルトメッセージの上書き方法については、「\ :ref:`Validation_message_def`\ 」を参照されたい。

|

.. _CreateWebApplicationProjectCustomizeErrorScreen:

エラー画面
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Maven Archetypeで作成したプロジェクトでは、エラーの種類毎にエラー画面を表示するためのJSP及びHTMLを提供しているが、

* 画面レイアウト
* 画面タイトル
* メッセージの文言

| などが簡易的な実装になっている。
| 例として、ブランクぽプロジェクトの実装(サンプリング)を以下に示す。
| \ **エラー画面を表示するためのJSPとHTMLについては、アプリケーション要件(UI規約など)に合わせて修正すること。**\

.. tabs::
  .. group-tab:: JSP

    \ **[JSP]**\
    
    .. code-block:: jsp
    
      <!DOCTYPE html>
      <html>
      <head>
      <meta charset="utf-8">
      <title>Resource Not Found Error!</title>
      <link rel="stylesheet" href="${pageContext.request.contextPath}/resources/app/css/styles.css">
      </head>
      <body>
          <div id="wrapper">
              <h1>Resource Not Found Error!</h1>
              <div class="error">
                  <c:if test="${!empty exceptionCode}">[${f:h(exceptionCode)}]</c:if>
                  <spring:message code="e.xx.fw.5001" />
              </div>
              <t:messagesPanel />
              <br>
              <!-- omitted -->
              <br>
          </div>
      </body>
      </html>

    |
    
    カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 45 45
    
      * - 項番
        - 対象ファイル
        - カスタマイズ方法
      * - 1.
        - エラー画面用のJSP
    
          \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/common/error/*.jsp``\
        - アプリケーション要件(UI規約など)に合わせて修正する。
    
          エラー画面を表示するJSPをカスタマイズする際は、「\ :doc:`../ArchitectureInDetail/WebApplicationDetail/ExceptionHandling`\ の \ :ref:`exception-handling-how-to-use-codingpoint-jsp-label`\ 」を参照されたい。
      * - 2.
        - エラー画面用のHTML
    
          \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/common/error/unhandledSystemError.html``\
        - アプリケーション要件(UI規約など)に合わせて修正する。

  .. group-tab:: Thymeleaf

    \ **[HTML]**\
    
    .. code-block:: html
    
      <!DOCTYPE html>
      <html xmlns:th="http://www.thymeleaf.org">
      <head>
      <meta charset="utf-8">
      <title>Resource Not Found Error!</title>
      <link rel="stylesheet"
          href="../../../../resources/app/css/styles.css" th:href="@{/resources/app/css/styles.css}">
      </head>
      <body>
          <div id="wrapper">
              <h1>Resource Not Found Error!</h1>
              <div class="error">
                  <span th:text="${#strings.isEmpty(exceptionCode)} ? #{e.xx.fw.5001} : |[${exceptionCode}] #{e.xx.fw.5001}|">[e.xx.fw.5001]
                      Resource not found.</span>
              </div>
              <div th:if="${resultMessages} != null" class="alert alert-error" th:class="|alert alert-${resultMessages.type}|">
                  <ul>
                      <li th:each="message : ${resultMessages}"
                          th:text="${message.code} != null ? ${#messages.msgWithParams(message.code, message.args)} : ${message.text}">error
                          detail message</li>
                  </ul>
              </div>
              <br>
              <!-- ... -->
              <br>
          </div>
      </body>
      </html>

    |
    
    カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 45 45
    
      * - 項番
        - 対象ファイル
        - カスタマイズ方法
      * - 1.
        - エラー画面用のテンプレートHTML
    
          \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/common/error/*.html(unhandledSystemError.htmlを除く)``\
        - アプリケーション要件(UI規約など)に合わせて修正する。
    
          エラー画面を表示するテンプレートHTMLをカスタマイズする際は、「\ :doc:`../ArchitectureInDetail/WebApplicationDetail/ExceptionHandling`\ の \ :ref:`exception-handling-how-to-use-codingpoint-jsp-label`\ 」を参照されたい。
      * - 2.
        - エラー画面用の静的なHTML
    
          \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/common/error/unhandledSystemError.html``\
        - アプリケーション要件(UI規約など)に合わせて修正する。

|

.. _CreateWebApplicationProjectCustomizeCopyrightOnScreenFooter:

画面フッターの著作権
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

| Maven Archetypeで作成したプロジェクトでは、画面フッター部の著作権が暫定値「\ ``Copyright &copy; 20XX CompanyName``\ 」の状態になっているため、適切な値を指定すること。
| 例として、ブランクプロジェクトの実装(サンプリング)を以下に示す。

.. tabs::
  .. group-tab:: JSP
    
    \ **[home.jsp]**\
    
    .. code-block:: jsp
    
      <div class="container">
          <jsp:include page="../layout/header.jsp" />
          <div id="wrapper">
              <h1 id="title">Hello world!</h1>
              <p>The time on the server is ${serverTime}.</p>
          </div>
          <hr>
          <jsp:include page="../layout/fotter.jsp" />
      </div>

    \ **[footer.jsp]**\
    
    .. code-block:: jsp
    
      <p style="text-align: center; background: #e5eCf9;">Copyright &copy; 20XX CompanyName</p>

    |

    カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 45 45
    
      * - 項番
        - 対象ファイル
        - カスタマイズ方法
      * - 1.
        - フッターJSP
    
          \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/layout/footer.jsp``\
        - 著作権の暫定値「\ ``Copyright &copy; 20XX CompanyName``\ 」を適切な値に修正する。

  .. group-tab:: Thymeleaf

    \ **[template.html]**\
    
    .. code-block:: html
    
      <!DOCTYPE html>
      <html class="no-js" xmlns:th="http://www.thymeleaf.org" th:fragment="layout (title,body)">
    
      <!-- ... -->
    
      <body>
          <div class="container">
          <!--/*/
              <div id="header" th:replace="~{layout/header :: header}"></div>
              <div id="body" th:replace="${body}"></div>
          /*/-->
          <!--/*-->
              <h1>
                  <a href="../welcome/home.html">projectName</a>
              </h1>
              <div id="wrapper">
                  <h1 id="title">Hello world!</h1>
                  <p>The time on the server is 2018/01/01 00:00:00 JST.</p>
              </div>
          <!--*/-->
              <hr>
              <p style="text-align: center; background: #e5eCf9;">Copyright &copy; 20XX CompanyName</p>
          </div>
      </body>
      </html>
    
    |
    
    カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 45 45
    
      * - 項番
        - 対象ファイル
        - カスタマイズ方法
      * - 1.
        - Thymeleafのテンプレートレイアウト用のHTMLファイル
    
          \ ``[artifactId]/[artifactId]-web/src/main/webapp/WEB-INF/views/layout/template.html``\
        - 著作権の暫定値「\ ``Copyright &copy; 20XX CompanyName``\ 」を適切な値に修正する。

|

.. _CreateWebApplicationProjectCustomizeInMemoryDatabase:

インメモリデータベース(H2 Database)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Maven Archetypeで作成したプロジェクトには、インメモリデータベース(H2 Database)をセットアップするための設定が行われているが、これはちょっとした動作検証(プロトタイプ作成やPOC(Proof Of Concept))を行うための設定である。そのため、本格的なアプリケーション開発を行う場合は、不要な設定になる。

.. note::

  \ **本格的なアプリケーション開発を行う場合は、インメモリデータベース(H2 Database)をセットアップするための定義とSQLを管理するためのディレクトリを削除すること。**\

.. tabs::
  .. group-tab:: Java Config

    \ **[artifactId]EnvConfig.java**\
    
    .. code-block:: java

      @Value("${database}")
      private String database;

      @Bean
      public DataSourceInitializer dataSourceInitializer() {
          DataSourceInitializer bean = new DataSourceInitializer();
          bean.setDataSource(dataSource());
  
          ResourceDatabasePopulator databasePopulator = new ResourceDatabasePopulator();
          databasePopulator.addScript(new ClassPathResource("/database/" + database + "-schema.sql"));
          databasePopulator.addScript(new ClassPathResource("/database/" + database + "-dataload.sql"));
          databasePopulator.setSqlScriptEncoding("UTF-8");
          databasePopulator.setIgnoreFailedDrops(true);
          bean.setDatabasePopulator(databasePopulator);
          return bean;
      }

    .. code-block:: console
    
      └── src
          └── main
              └── resources
                  ├── META-INF
                (...)
                  ├── database
                  │   ├── H2-dataload.sql
                  │   └── H2-schema.sql

    |
    
    カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 45 45
    
      * - 項番
        - 対象ファイル
        - カスタマイズ方法
      * - 1.
        - 環境依存するコンポーネントを定義するBean定義ファイル
    
          \ ``[artifactId]-env/src/main/java/com/example/todo/config/app/[artifactId]EnvConfig.java``\
        - \ ``DataSourceInitializer``\ Beanを削除する。
      * - 2.
        - インメモリデータベース(H2 Database)をセットアップするためのSQLを格納するディレクトリ
    
          \ ``[artifactId]/[artifactId]-env/src/main/resources/database/``\
        - ディレクトリを削除する。

  .. group-tab:: XML Config

    \ **[artifactId]-env.xml**\
    
    .. code-block:: xml
    
      <jdbc:initialize-database data-source="dataSource"
          ignore-failures="ALL">
          <jdbc:script location="classpath:/database/${database}-schema.sql" encoding="UTF-8" />
          <jdbc:script location="classpath:/database/${database}-dataload.sql" encoding="UTF-8" />
      </jdbc:initialize-database>

    .. code-block:: console
    
      └── src
          └── main
              └── resources
                  ├── META-INF
                (...)
                  ├── database
                  │   ├── H2-dataload.sql
                  │   └── H2-schema.sql

    |
    
    カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 45 45
    
      * - 項番
        - 対象ファイル
        - カスタマイズ方法
      * - 1.
        - 環境依存するコンポーネントを定義するBean定義ファイル
    
          \ ``[artifactId]-env/src/main/resources/META-INF/spring/[artifactId]-env.xml``\
        - \ ``<jdbc:initialize-database>``\ 要素を削除する。
      * - 2.
        - インメモリデータベース(H2 Database)をセットアップするためのSQLを格納するディレクトリ
    
          \ ``[artifactId]/[artifactId]-env/src/main/resources/database/``\
        - ディレクトリを削除する。

|

.. _CreateWebApplicationProjectCustomizeDataSource:

データソース設定
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Maven Archetypeで作成したプロジェクトでは、インメモリデータベース(H2 Database)にアクセスするためのデータソース設定が行われているが、これはちょっとした動作検証(プロトタイプ作成やPOC(Proof Of Concept))を行うための設定である。そのため、本格的なアプリケーション開発を行う場合は、アプリケーション稼働時に利用するデータベースにアクセスするためのデータソース設定に変更する必要がある。

\ **[artifactId]/[artifactId]-domain/pom.xml**\

.. code-block:: xml

  <dependency>
      <groupId>com.h2database</groupId>
      <artifactId>h2</artifactId>
      <scope>runtime</scope>
  </dependency>

.. note::

  上記設定例は、依存ライブラリのバージョンをBOMプロジェクトである terasoluna-dependencies で管理する前提であるため、pom.xmlでのバージョンの指定は不要である。

  上記の依存ライブラリはterasoluna-dependenciesが依存している\ `Spring Boot <https://docs.spring.io/spring-boot/3.4.1/appendix/dependency-versions/coordinates.html>`_\ で管理されている。

\ **[artifactId]-infra.properties**\

.. code-block:: properties

  database=H2
  database.url=jdbc:h2:mem:todo;DB_CLOSE_DELAY=-1
  database.username=sa
  database.password=
  database.driverClassName=org.h2.Driver
  # connection pool
  cp.maxActive=96
  cp.maxIdle=16
  cp.minIdle=0
  cp.maxWait=60000

.. tabs::
  .. group-tab:: Java Config

    \ **[artifactId]EnvConfig.java**\
    
    .. code-block:: java

      @Value("${database.url}")
      private String url;
  
      @Value("${database.username}")
      private String username;
  
      @Value("${database.password}")
      private String password;
  
      @Value("${cp.maxActive}")
      private Integer maxActive;
  
      @Value("${cp.maxIdle}")
      private Integer maxIdle;
  
      @Value("${cp.minIdle}")
      private Integer minIdle;
  
      @Value("${cp.maxWait}")
      private Integer maxWait;

      @Bean(name = "dataSource", destroyMethod = "close")
      public DataSource dataSource() {
          BasicDataSource bean = new BasicDataSource();
          bean.setDriverClassName(driverClassName);
          bean.setUrl(url);
          bean.setUsername(username);
          bean.setPassword(password);
          bean.setDefaultAutoCommit(false);
          bean.setMaxTotal(maxActive);
          bean.setMaxIdle(maxIdle);
          bean.setMinIdle(minIdle);
          bean.setMaxWait(Duration.ofMillis(maxWait));
          return bean;
      }

  .. group-tab:: XML Config

    \ **[artifactId]-env.xml**\
    
    .. code-block:: xml
    
      <bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"
          destroy-method="close">
          <property name="driverClassName" value="${database.driverClassName}" />
          <property name="url" value="${database.url}" />
          <property name="username" value="${database.username}" />
          <property name="password" value="${database.password}" />
          <property name="defaultAutoCommit" value="false" />
          <property name="maxTotal" value="${cp.maxActive}" />
          <property name="maxIdle" value="${cp.maxIdle}" />
          <property name="minIdle" value="${cp.minIdle}" />
          <property name="maxWait" >
            <bean class="java.time.Duration" factory-method="ofMillis">
              <constructor-arg value="${cp.maxWait}" />
            </bean>
          </property>
      </bean>

.. note::

  \ **本格的なアプリケーション開発を行う場合は、アプリケーション稼働時に利用するデータベースにアクセスするためのデータソース設定に変更すること。**\

  Maven Archetypeで作成したプロジェクトでは、Apache Commons DBCPを使用する設定となっているが、アプリケーションサーバから提供されているデータソースを使用して、JNDI(Java Naming and Directory Interface)経由でデータソースにアクセスする方法を採用するケースも多い。

  開発環境ではApache Commons DBCPのデータソースを使用して、テスト環境及び商用環境ではアプリケーションサーバから提供されているデータソースを使用するといった使い分けを行うケースもある。

  データソースの設定方法については、「\ :doc:`../ArchitectureInDetail/DataAccessDetail/DataAccessCommon`\ の \ :ref:`data-access-common_howtouse_datasource`\ 」を参照されたい。

|

カスタマイズ対象のファイルとカスタマイズ方法を以下に示す。

.. tabularcolumns:: |p{0.10\linewidth}|p{0.45\linewidth}|p{0.45\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 45 45

  * - 項番
    - 対象ファイル
    - カスタマイズ方法
  * - 1.
    - POMファイル

      * \ ``[artifactId]/pom.xml``\
      * \ ``[artifactId]/[artifactId]-web/pom.xml``\
    - インメモリデータベース(H2 Database)のJDBCドライバを依存ライブラリから削除する。

      アプリケーション稼働時に利用するデータベースにアクセスするためのJDBCドライバを依存ライブラリに追加する。

  * - 2.
    - 環境依存する設定値を定義するプロパティファイル

      \ ``[artifactId]/[artifactId]-env/src/main/resources/META-INF/spring/[artifactId]-infra.properties``\
    - データソースとしてApache Commons DBCPを使用する場合は、以下のプロパティにアプリケーション稼働時に利用するデータベースにアクセスするための接続情報を指定する。

      * \ ``database``\
      * \ ``database.url``\
      * \ ``database.username``\
      * \ ``database.password``\
      * \ ``database.driverClassName``\

      アプリケーションサーバから提供されているデータソースを使用する場合は、以下のプロパティ以外は不要なプロパティになるので削除する。

      * \ ``database``\

  * - 3.
    - 環境依存するコンポーネントを定義するBean定義ファイル

      .. tabs::
        .. group-tab:: Java Config

          \ ``[artifactId]/[artifactId]-env/src/main/java/com/example/project/config/app/[artifactId]EnvConfig.java``\

        .. group-tab:: XML Config

          \ ``[artifactId]/[artifactId]-env/src/main/resources/META-INF/spring/[artifactId]-env.xml``\

    - アプリケーションサーバから提供されているデータソースを使用する場合は、JNDI経由で取得したデータソースを使用するように設定を変更する。

      データソースの設定方法については、「\ :doc:`../ArchitectureInDetail/DataAccessDetail/DataAccessCommon`\ の \ :ref:`data-access-common_howtouse_datasource`\ 」を参照されたい。

.. note:: \ **環境依存する設定値を定義するプロパティファイルのdatabaseプロパティについて**\

  O/R MapperとしてMyBatisを使用する場合は、\ ``database``\ プロパティは不要なプロパティである。削除してもよいが、使用しているデータベースを明示するために設定を残しておいてもよい。

.. tip:: \ **JDBCドライバの追加方法について**\

  使用するデータベースがPostgreSQLとOracleの場合は、POMファイル内のコメントアウトを外せばよい。JDBCドライバのバージョンについては、使用するデータベースのバージョンに対応するバージョンに修正すること。

  ただしOracleを使用する場合は、コメントを外す前に、MavenのローカルリポジトリにOracleのJDBCドライバをインストールしておく必要がある。

  以下は、PostgreSQLを使用する場合の設定例である。

  * \ ``[artifactId]/pom.xml``\

    .. code-block:: xml

                   <dependency>
                       <groupId>org.postgresql</groupId>
                       <artifactId>postgresql</artifactId>
                       <version>${postgresql.version}</version>
                   </dependency>
      <!--         <dependency> -->
      <!--             <groupId>com.oracle.database.jdbc</groupId> -->
      <!--             <artifactId>ojdbc17</artifactId> -->
      <!--             <version>${ojdbc.version}</version> -->
      <!--         </dependency> -->

                   <!-- omitted -->

                   <postgresql.version>42.7.4</postgresql.version>
                   <ojdbc.version>23.6.0.24.10</ojdbc.version>

  * \ ``[artifactId]/[artifactId]-web/pom.xml``\

    .. code-block:: xml

                   <dependency>
                      <groupId>org.postgresql</groupId>
                      <artifactId>postgresql</artifactId>
                       <scope>runtime</scope>
                   </dependency>
      <!--         <dependency> -->
      <!--             <groupId>com.oracle.database.jdbc</groupId> -->
      <!--             <artifactId>ojdbc17</artifactId> -->
      <!--             <scope>runtime</scope> -->
      <!--         </dependency> -->

    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90

      * - 項番
        - 説明
      * - | (1)
        - JDBCドライバはコンパイルには使用せず、アプリケーション実行時のみ使用するため、\ ``runtime``\ スコープを指定している。

          単体テストで使用する場合などは、適切なスコープに変更して使用されたい。

|

.. _CreateWebApplicationProjectConfiguration:

開発プロジェクトの構成
--------------------------------------------------------------------------------

Maven Archetypeで作成したプロジェクトの構成について説明する。

Maven Archetypeで作成したプロジェクトは、以下の構成になっている。

* 本ガイドラインで推奨しているレイヤ毎のプロジェクト構成
* 本ガイドラインで紹介している環境依存性の排除を考慮したプロジェクト構成
* CI(Continuous Integration)を意識したプロジェクト構成

また、本ガイドラインで推奨している各種設定が盛り込まれた、

* Webアプリケーションの構成定義ファイル(web.xml)
* Spring FrameworkのBean定義ファイル
* Spring MVC用のBean定義ファイル
* Spring Security用のBean定義ファイル
* O/R Mapperの設定ファイル
* プロパティファイル(メッセージ定義ファイルなど)

と、アプリケーション要件との依存度が低い(=どんなアプリケーションでも作成する必要がある)コンポーネントの簡易実装として、

* Welcomeページを表示するためのControllerとJSPまたはテンプレートHTML
* エラー画面を表示するためのJSP(HTML)またはテンプレートHTML
* JSPタグライブラリの読み込み設定などが定義されているインクルード用JSP
* Thymeleafのテンプレートレイアウト用のHTML
* アプリケーション全体の画面スタイルを定義するCSSファイル

などが提供されている。

.. warning:: \ **簡易実装として提供しているコンポーネントの扱いについて**\

  簡易実装として提供しているコンポーネントは、以下のいずれかの対応を行うこと。

  * アプリケーション要件にあわせて修正
  * 不要なコンポーネントは削除

.. note:: \ **REST API用のプロジェクトを作成する場合の手順について**\

  Maven Archetypeで作成したプロジェクトは、伝統的なWebアプリケーション(リクエストパラメータを受け取ってHTMLを応答するアプリケーション)を構築する際に必要となる推奨設定が行われている。

  そのため、JSONやXMLを扱うREST APIを構築する際には不要な設定が存在する。
  REST APIを構築するためのプロジェクトを作成する場合は、「\ :doc:`../ArchitectureInDetail/WebServiceDetail/REST`\ の \ :ref:`RESTHowToUseApplicationSettings`\ 」を参照し、REST API向けの設定を適用してほしい。

|

.. _CreateWebApplicationProjectConfigurationMulti:

マルチプロジェクトの構成
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

まず、マルチプロジェクト全体の構成について説明する。

.. code-block:: console

  [artifactId]
      ├── pom.xml  ... (1)
      ├── [artifactId]-web  ... (2)
      ├── [artifactId]-domain  ... (3)
      ├── [artifactId]-env  ... (4)
      ├── [artifactId]-initdb  ... (5)
      └── [artifactId]-selenium  ... (6)

.. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 90
  :class: longtable

  * - | 項番
    - | 説明
  * - | (1)
    - マルチプロジェクト全体の構成を定義するPOM(Project Object Model)ファイル。

      このファイルでは、主に以下の定義を行う。

      * 依存ライブラリのバージョン
      * ビルド用のプラグインの設定(ビルド方法の設定)

      マルチプロジェクトの階層関係については、「\ :ref:`CreateWebApplicationProjectAppendixProjectHierarchicalStructure`\ 」を参照されたい。

  * - | (2)
    - アプリケーション層(Web層)のコンポーネントを管理するモジュール。

      このモジュールでは、主に以下のコンポーネントやファイルを管理する。

      * Controllerクラス
      * 相関チェック用のValidatorクラス
      * Formクラス(REST APIの場合はResourceクラス)
      * View(JSP/Thymeleaf)
      * CSSファイル
      * JavaScriptファイル
      * アプリケーション層のコンポーネント用のJUnit
      * アプリケーション層のコンポーネントを定義するためのBean定義ファイル
      * Webアプリケーションの構成定義ファイル(web.xml)
      * メッセージ定義ファイル

  * - | (3)
    - ドメイン層のコンポーネントを管理するモジュール。

      このモジュールでは、主に以下のコンポーネントやファイルを管理する。

      * Entityなどのドメインオブジェクト
      * Repository
      * Service
      * DTO
      * ドメイン層のコンポーネント用のJUnit
      * ドメイン層のコンポーネントを定義するためのBean定義ファイル

  * - | (4)
    - 環境依存性をもつ設定ファイルを管理するモジュール。

      このモジュールでは、主に以下のファイルを管理する。

      * 環境依存するコンポーネントを定義するためのBean定義ファイル
      * 環境依存するプロパティ値を定義するプロパティファイル

  * - | (5)
    - データベースを初期化するためのSQLファイルを管理するモジュール

      このモジュールでは、主に以下のファイルを管理する。

      * テーブルなどのデータベースオブジェクトを作成するためのSQLファイル
      * マスタデータなどの初期データを投入するためのSQLファイル
      * E2E(End To End)テストで使用するテストデータを投入するためのSQLファイル

  * - | (6)
    - Seleniumを使用したE2Eテスト用のコンポーネントを管理するモジュール。

      このモジュールでは、主に以下のファイルを管理する。

      * Seleniumを操作してテストを行うJUnit
      * Assert時に使用する期待値ファイル(必要に応じて)

.. note:: \ **本ガイドラインにおける「マルチプロジェクト」の用語定義について**\

  Maven Archetypeで作成したプロジェクトは、正確にはマルチモジュール構成のプロジェクトとなる。

  本ガイドラインでは、マルチモジュールとマルチプロジェクトを同じ意味で使用していることを補足しておく。

.. note:: \ **2つのWebアプリケーションと1つの共通ライブラリが必要となる開発プロジェクトについて**\

  * | bar-parent
  * | bar-initdb
  * | bar-common
  * | bar-common-web
  * | bar-domain-a
  * | bar-domain-b
  * | bar-web-a
  * | bar-web-b
  * | bar-env
  * | bar-web-a-selenium
  * | bar-web-b-selenium

  それぞれのプロジェクトの内容は下記のようになる。

  * | bar-parent

    | parent-pom(親POM)と呼ばれるプロジェクト。pom.xmlファイルだけを持ち、その他のソースコードや設定ファイルは一切持たない、シンプルなプロジェクト。
    | 他のプロジェクトのpom上で、このbar-parentプロジェクトを<parent>タグに指定することによって、親POMに指定された共通設定情報を自身に反映させることができる。
  * | bar-initdb

    | RDBMSのテーブル定義(DDL)と初期データをINSERTするためのSQL文を格納する。これもmavenプロジェクトとして管理する。
    | pom.xmlに\ `sql-maven-plugin <http://www.mojohaus.org/sql-maven-plugin/>`_\ の設定を定義することにより、ビルドライフサイクルの過程で任意のRDBMSに対するDDL文や初期データINSERT文の実行を自動化することができる。
  * | bar-common

    | プロジェクト共通ライブラリを格納する。ここはweb非依存にし、webに関わるクラスはbar-common-webに配置する。
  * | bar-common-web

    | プロジェクト共通webライブラリを格納する
  * | bar-domain-a

    | aドメインに関わるドメイン層のjavaクラス、単体テストケース等を格納するプロジェクト。最終的に*.jarファイル化する。
  * | bar-domain-b

    | bドメインに関わるドメイン層のクラス。
  * | bar-web-a

    | アプリケーション層のjavaクラス、jsp/html、設定ファイル、単体テストケース等を格納するプロジェクト。最終的にWebアプリケーションとして*.warファイル化する。
    | bar-web-aは、bar-commonとbar-envへの依存性を持つ。
  * | bar-web-b

    | もう一つのサブシステムとしてのWebアプリケーション。構造はbar-web-aと同じ。
  * | bar-env

    | 環境依存性のある設定ファイルだけを集めるプロジェクト。
  * | bar-web-a-selenium

    | web-aプロジェクトのための、\ `Selenium WebDriver <https://www.selenium.dev/>`_\ によるテストケースを格納するプロジェクト。
  * | bar-web-b-selenium

    | web-bプロジェクトのための、\ `Selenium WebDriver <https://www.selenium.dev/>`_\ によるテストケースを格納するプロジェクト。

|

.. _CreateWebApplicationProjectConfigurationWeb:

webモジュールの構成
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

アプリケーション層(Web層)のコンポーネントを管理するモジュールの構成について説明する。

.. code-block:: console

  [artifactId]-web
      ├── pom.xml  ... (1)

.. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 90

  * - | 項番
    - | 説明
  * - | (1)
    - webモジュールの構成を定義するPOM(Project Object Model)ファイル。このファイルでは、以下の定義を行う。

      * 依存ライブラリとビルド用プラグインの定義
      * warファイルを作成するための定義

.. note:: \ **REST API用のプロジェクトを作成する際のwebモジュールのモジュール名について**\

  REST APIを構築する場合は、モジュール名を\ ``[artifactId]-api``\ といった感じの名前にしておくと、アプリケーションの種類が識別しやすくなる。

|

.. tabs::
  .. group-tab:: Java Config

    .. tabs::
      .. group-tab:: JSP
        
        .. code-block:: console
        
          └── src
              ├── main
              │   ├── java
              │   │   └── com
              │   │       └── example
              │   │           └── project
              │   │               ├── app  ... (2)
              │   │               │   └── welcome
              │   │               │         └── HelloController.java  ... (4)
              │   │               └── config
              │   │                   ├── app
              │   │                   │     └── ApplicationContextConfig.java  ... (7)
              │   │                   └── web
              │   │                         ├── SpringMvcConfig.java  ... (8)
              │   │                         └── SpringSecurityConfig.java  ... (9)
              │   ├── resources
              │   │   ├── META-INF
              │   │   │   └── spring  ... (5)
              │   │   │       └── application.properties  ... (6)
              │   │   └── i18n  ... (10)
              │   │       └── application-messages.properties  ... (11)
        
        .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
        .. list-table::
            :header-rows: 1
            :widths: 10 90
            :class: longtable
        
            * - | 項番
              - | 説明
            * - | (2)
              - アプリケーション層のクラスを格納するためのパッケージ。
        
                REST APIを構築する場合は、パッケージ名を\ ``api``\ といった感じの名前にしておくと、
                コンポーネントの種類が識別しやすくなる。
            * - | (4)
              - Welcomeページを表示するためのリクエストを受け取るためのControllerクラス。
            * - | (5)
              - Spring FrameworkのBean定義ファイルとプロパティファイルを格納するディレクトリ。
            * - | (6)
              - アプリケーション層で使用する設定値を定義するプロパティファイル。
        
                作成時点では、空のファイルである。
            * - | (7)
              - Webアプリケーション用のアプリケーションコンテキストを作成するためのBean定義ファイル。
        
                このファイルには、以下のBeanを定義する。
        
                * Webアプリケーション全体で使用するコンポーネント
                * ドメイン層のコンポーネント(ドメイン層のコンポーネントが定義されているBean定義ファイルをimportする)
        
            * - | (8)
              - \ ``DispatcherServlet``\ 用のアプリケーションコンテキストを作成するためのBean定義ファイル。
        
                このファイルには、以下のBeanを定義する。
        
                * Spring MVCのコンポーネント
                * アプリケーション層のコンポーネント
        
                REST APIを構築する場合は、ファイル名を\ ``SpringMvcApiConfig.java``\ といった感じの名前にしておくと、 アプリケーションの種類が識別しやすくなる。
        
            * - | (9)
              - Spring Securityのコンポーネントを定義するためのBean定義ファイル。
        
                このファイルは、Webアプリケーション用のアプリケーションコンテキストを作成する際に読み込む。
            * - | (10)
              - アプリケーション層で使用するメッセージ定義ファイルを格納するディレクトリ。
            * - | (11)
              - | アプリケーション層で使用するメッセージを定義するプロパティファイル。
              
                | 作成時点では、いくつかの汎用的なメッセージが定義されている。
                | \ **アプリケーションの要件(メッセージ規約など)にあわせて必ず修正すること。**\
                | メッセージ定義については、「\ :doc:`../ArchitectureInDetail/WebApplicationDetail/MessageManagement`\ 」を参照されたい。
    
      .. group-tab:: Thymeleaf
        
        .. code-block:: console
        
          └── src
              ├── main
              │   ├── java
              │   │   └── com
              │   │       └── example
              │   │           └── project
              │   │               ├── app  ... (2)
              │   │               │   ├── common
              │   │               │   │  └── error
              │   │               │   │      └── CommonErrorController.java  ... (3)
              │   │               │   └── welcome
              │   │               │       └── HelloController.java  ... (4)
              │   │               └── config
              │   │                   ├── app
              │   │                   │     └── ApplicationContextConfig.java  ... (7)
              │   │                   └── web
              │   │                         ├── SpringMvcConfig.java  ... (8)
              │   │                         └── SpringSecurityConfig.java  ... (9)
              │   ├── resources
              │   │   ├── META-INF
              │   │   │   └── spring  ... (5)
              │   │   │       └── application.properties  ... (6)
              │   │   └── i18n  ... (10)
              │   │       └── application-messages.properties  ... (11)
        
        .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
        .. list-table::
            :header-rows: 1
            :widths: 10 90
            :class: longtable
        
            * - | 項番
              - | 説明
            * - | (2)
              - アプリケーション層のクラスを格納するためのパッケージ。
        
                REST APIを構築する場合は、パッケージ名を\ ``api``\ といった感じの名前にしておくと、
                コンポーネントの種類が識別しやすくなる。
            * - | (3)
              - エラー画面を表示するためのControllerクラス。
            * - | (4)
              - Welcomeページを表示するためのリクエストを受け取るためのControllerクラス。
            * - | (5)
              - Spring FrameworkのBean定義ファイルとプロパティファイルを格納するディレクトリ。
            * - | (6)
              - アプリケーション層で使用する設定値を定義するプロパティファイル。
        
                作成時点では、空のファイルである。
            * - | (7)
              - Webアプリケーション用のアプリケーションコンテキストを作成するためのBean定義ファイル。
        
                このファイルには、以下のBeanを定義する。
        
                * Webアプリケーション全体で使用するコンポーネント
                * ドメイン層のコンポーネント(ドメイン層のコンポーネントが定義されているBean定義ファイルをimportする)
        
            * - | (8)
              - \ ``DispatcherServlet``\ 用のアプリケーションコンテキストを作成するためのBean定義ファイル。
        
                このファイルには、以下のBeanを定義する。
        
                * Spring MVCのコンポーネント
                * アプリケーション層のコンポーネント
        
                REST APIを構築する場合は、ファイル名を\ ``spring-mvc-api.xml``\ といった感じの名前にしておくと、 アプリケーションの種類が識別しやすくなる。
        
            * - | (9)
              - Spring Securityのコンポーネントを定義するためのBean定義ファイル。
        
                このファイルは、Webアプリケーション用のアプリケーションコンテキストを作成する際に読み込む。
            * - | (10)
              - アプリケーション層で使用するメッセージ定義ファイルを格納するディレクトリ。
            * - | (11)
              - | アプリケーション層で使用するメッセージを定義するプロパティファイル。
      
                | 作成時点では、いくつかの汎用的なメッセージが定義されている。
                | \ **アプリケーションの要件(メッセージ規約など)にあわせて必ず修正すること。**\
                | メッセージ定義については、「\ :doc:`../ArchitectureInDetail/WebApplicationDetail/MessageManagement`\ 」を参照されたい。

  .. group-tab:: XML Config

    .. tabs::
      .. group-tab:: JSP
        
        .. code-block:: console
        
          └── src
              ├── main
              │   ├── java
              │   │   └── com
              │   │       └── example
              │   │           └── project
              │   │               └── app  ... (2)
              │   │                   └── welcome
              │   │                       └── HelloController.java  ... (4)
              │   ├── resources
              │   │   ├── META-INF
              │   │   │   └── spring  ... (5)
              │   │   │       ├── application.properties  ... (6)
              │   │   │       ├── applicationContext.xml  ... (7)
              │   │   │       ├── spring-mvc.xml  ... (8)
              │   │   │       └── spring-security.xml  ... (9)
              │   │   └── i18n  ... (10)
              │   │       └── application-messages.properties  ... (11)
        
        .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
        .. list-table::
            :header-rows: 1
            :widths: 10 90
            :class: longtable
        
            * - | 項番
              - | 説明
            * - | (2)
              - アプリケーション層のクラスを格納するためのパッケージ。
        
                REST APIを構築する場合は、パッケージ名を\ ``api``\ といった感じの名前にしておくと、
                コンポーネントの種類が識別しやすくなる。
            * - | (4)
              - Welcomeページを表示するためのリクエストを受け取るためのControllerクラス。
            * - | (5)
              - Spring FrameworkのBean定義ファイルとプロパティファイルを格納するディレクトリ。
            * - | (6)
              - アプリケーション層で使用する設定値を定義するプロパティファイル。
        
                作成時点では、空のファイルである。
            * - | (7)
              - Webアプリケーション用のアプリケーションコンテキストを作成するためのBean定義ファイル。
        
                このファイルには、以下のBeanを定義する。
        
                * Webアプリケーション全体で使用するコンポーネント
                * ドメイン層のコンポーネント(ドメイン層のコンポーネントが定義されているBean定義ファイルをimportする)
        
            * - | (8)
              - \ ``DispatcherServlet``\ 用のアプリケーションコンテキストを作成するためのBean定義ファイル。
        
                このファイルには、以下のBeanを定義する。
        
                * Spring MVCのコンポーネント
                * アプリケーション層のコンポーネント
        
                REST APIを構築する場合は、ファイル名を\ ``spring-mvc-api.xml``\ といった感じの名前にしておくと、 アプリケーションの種類が識別しやすくなる。
        
            * - | (9)
              - Spring Securityのコンポーネントを定義するためのBean定義ファイル。
        
                このファイルは、Webアプリケーション用のアプリケーションコンテキストを作成する際に読み込む。
            * - | (10)
              - アプリケーション層で使用するメッセージ定義ファイルを格納するディレクトリ。
            * - | (11)
              - | アプリケーション層で使用するメッセージを定義するプロパティファイル。
              
                | 作成時点では、いくつかの汎用的なメッセージが定義されている。
                | \ **アプリケーションの要件(メッセージ規約など)にあわせて必ず修正すること。**\
                | メッセージ定義については、「\ :doc:`../ArchitectureInDetail/WebApplicationDetail/MessageManagement`\ 」を参照されたい。
    
      .. group-tab:: Thymeleaf
        
        .. code-block:: console
        
          └── src
              ├── main
              │   ├── java
              │   │   └── com
              │   │       └── example
              │   │           └── project
              │   │               └── app  ... (2)
              │   │                   ├── common
              │   │                   │  └── error
              │   │                   │      └── CommonErrorController.java  ... (3)
              │   │                   └── welcome
              │   │                       └── HelloController.java  ... (4)
              │   ├── resources
              │   │   ├── META-INF
              │   │   │   └── spring  ... (5)
              │   │   │       ├── application.properties  ... (6)
              │   │   │       ├── applicationContext.xml  ... (7)
              │   │   │       ├── spring-mvc.xml  ... (8)
              │   │   │       └── spring-security.xml  ... (9)
              │   │   └── i18n  ... (10)
              │   │       └── application-messages.properties  ... (11)
        
        .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
        .. list-table::
            :header-rows: 1
            :widths: 10 90
            :class: longtable
        
            * - | 項番
              - | 説明
            * - | (2)
              - アプリケーション層のクラスを格納するためのパッケージ。
        
                REST APIを構築する場合は、パッケージ名を\ ``api``\ といった感じの名前にしておくと、
                コンポーネントの種類が識別しやすくなる。
            * - | (3)
              - エラー画面を表示するためのControllerクラス。
            * - | (4)
              - Welcomeページを表示するためのリクエストを受け取るためのControllerクラス。
            * - | (5)
              - Spring FrameworkのBean定義ファイルとプロパティファイルを格納するディレクトリ。
            * - | (6)
              - アプリケーション層で使用する設定値を定義するプロパティファイル。
        
                作成時点では、空のファイルである。
            * - | (7)
              - Webアプリケーション用のアプリケーションコンテキストを作成するためのBean定義ファイル。
        
                このファイルには、以下のBeanを定義する。
        
                * Webアプリケーション全体で使用するコンポーネント
                * ドメイン層のコンポーネント(ドメイン層のコンポーネントが定義されているBean定義ファイルをimportする)
        
            * - | (8)
              - \ ``DispatcherServlet``\ 用のアプリケーションコンテキストを作成するためのBean定義ファイル。
        
                このファイルには、以下のBeanを定義する。
        
                * Spring MVCのコンポーネント
                * アプリケーション層のコンポーネント
        
                REST APIを構築する場合は、ファイル名を\ ``spring-mvc-api.xml``\ といった感じの名前にしておくと、 アプリケーションの種類が識別しやすくなる。
        
            * - | (9)
              - Spring Securityのコンポーネントを定義するためのBean定義ファイル。
        
                このファイルは、Webアプリケーション用のアプリケーションコンテキストを作成する際に読み込む。
            * - | (10)
              - アプリケーション層で使用するメッセージ定義ファイルを格納するディレクトリ。
            * - | (11)
              - | アプリケーション層で使用するメッセージを定義するプロパティファイル。
      
                | 作成時点では、いくつかの汎用的なメッセージが定義されている。
                | \ **アプリケーションの要件(メッセージ規約など)にあわせて必ず修正すること。**\
                | メッセージ定義については、「\ :doc:`../ArchitectureInDetail/WebApplicationDetail/MessageManagement`\ 」を参照されたい。

.. note::

  アプリケーションコンテキストとBean定義ファイルの関連については、「\ :ref:`CreateWebApplicationProjectAppendixApplicationContext`\ 」を参照されたい。

|

.. tabs::
  .. group-tab:: JSP

    .. code-block:: console
    
      │   └── webapp
      │       ├── WEB-INF
      │       │   ├── views  ... (12)
      │       │   │   ├── common
      │       │   │   │   ├── error  ... (13)
      │       │   │   │   │   ├── accessDeniedError.jsp
      │       │   │   │   │   ├── businessError.jsp
      │       │   │   │   │   ├── dataAccessError.jsp
      │       │   │   │   │   ├── invalidCsrfTokenError.jsp
      │       │   │   │   │   ├── missingCsrfTokenError.jsp
      │       │   │   │   │   ├── resourceNotFoundError.jsp
      │       │   │   │   │   ├── systemError.jsp
      │       │   │   │   │   ├── transactionTokenError.jsp
      │       │   │   │   │   └── unhandledSystemError.html
      │       │   │   │   └── include.jsp  ... (14)
      │       │   │   ├── layout  ... (15)
      │       │   │   │   ├── header.jsp
      │       │   │   │   └── footer.jsp
      │       │   │   └── welcome
      │       │   │       └── home.jsp  ... (16)
      │       │   └── web.xml  ... (17)
      │       └── resources  ... (18)
      │           └── app
      │               └── css
      │                   └── styles.css  ... (19)
      └── test
          ├── java
          └── resources
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
      :class: longtable
    
      * - | 項番
        - | 説明
      * - | (12)
        - Viewを構築するテンプレートファイル(JSPなど)を格納するディレクトリ。
      * - | (13)
        - | エラー画面を表示するためのJSP及びHTMLを格納するディレクトリ。
         
          | 作成時点では、アプリケーション実行時に発生する可能性があるエラーに対応するJSP(HTML)が格納されている。
          | \ **アプリケーションの要件(UI規約など)にあわせて必ず修正すること。**\
      * - | (14)
        - | インクルード用の共通JSPファイル。

          | このファイルは、全てのJSPファイルの先頭にインクルードされる。
          | インクルード用の共通JSPファイルについては、「\ :ref:`view_jsp_include-label`\ 」を参照されたい。
      * - | (15)
        - 共通化するJSPファイルを格納する格納するディレクトリ。
      * - | (16)
        - Welcomeページを表示するJSPファイル。
      * - | (17)
        - Webアプリケーションの構成定義ファイル。
      * - | (18)
        - 静的なリソースファイルを格納するディレクトリ。
    
          | このディレクトリは、リクエストの内容によって応答する内容がかわらないファイルを格納する。
          | 具体的には以下のファイルを格納する。
    
          * JavaScriptファイル
          * CSSファイル
          * 画像ファイル
          * HTMLファイル
    
          Spring MVCが提供する静的リソースの管理メカニズムを適用しやすくするために、専用のディレクトリを設ける構成を採用している。
      * - | (19)
        - アプリケーション全体に適用する画面スタイルを定義するCSSファイル。

  .. group-tab:: Thymeleaf

    .. code-block:: console
    
      │   └── webapp
      │       ├── WEB-INF
      │       │   ├── views  ... (12)
      │       │   │   ├── common
      │       │   │   │   └── error  ... (13)
      │       │   │   │        ├── accessDeniedError.html
      │       │   │   │        ├── businessError.html
      │       │   │   │        ├── dataAccessError.html
      │       │   │   │        ├── invalidCsrfTokenError.html
      │       │   │   │        ├── missingCsrfTokenError.html
      │       │   │   │        ├── resourceNotFoundError.html
      │       │   │   │        ├── systemError.html
      │       │   │   │        ├── transactionTokenError.html
      │       │   │   │        └── unhandledSystemError.html
      │       │   │   ├── layout  ... (15)
      │       │   │   │   ├── header.html
      │       │   │   │   └── template.html
      │       │   │   └── welcome
      │       │   │       └── home.html  ... (16)
      │       │   └── web.xml  ... (17)
      │       └── resources  ... (18)
      │           └── app
      │               └── css
      │                   └── styles.css  ... (19)
      └── test
          ├── java
          └── resources
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
      :class: longtable
    
      * - | 項番
        - | 説明
      * - | (12)
        - Viewを構築するテンプレートファイル(HTMLなど)を格納するディレクトリ。
      * - | (13)
        - | エラー画面を表示するためのテンプレートHTML及び静的なHTMLを格納するディレクトリ。
        
          | 作成時点では、アプリケーション実行時に発生する可能性があるエラーに対応するテンプレートHTML及び静的なHTMLが格納されている。
          | \ **アプリケーションの要件(UI規約など)にあわせて必ず修正すること。**\
      * - | (15)
        - | Thymeleafのテンプレートレイアウト用のHTMLファイルを格納するディレクトリ。

          | Thymeleafのテンプレートレイアウト用のHTMLファイルの記載内容については、「\ :doc:`../ArchitectureInDetail/WebApplicationDetail/TemplateLayout`\ 」を参照されたい。
      * - | (16)
        - Welcomeページを表示するテンプレートHTMLファイル。
      * - | (17)
        - Webアプリケーションの構成定義ファイル。
      * - | (18)
        - 静的なリソースファイルを格納するディレクトリ。
    
          | このディレクトリは、リクエストの内容によって応答する内容がかわらないファイルを格納する。
          | 具体的には以下のファイルを格納する。
    
          * JavaScriptファイル
          * CSSファイル
          * 画像ファイル
          * HTMLファイル
    
          Spring MVCが提供する静的リソースの管理メカニズムを適用しやすくするために、専用のディレクトリを設ける構成を採用している。
      * - | (19)
        - アプリケーション全体に適用する画面スタイルを定義するCSSファイル。

|

.. _CreateWebApplicationProjectConfigurationDomain:

domainモジュールの構成
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

ドメイン層のコンポーネントを管理するモジュールの構成について説明する。

.. code-block:: console

  [artifactId]-domain
      ├── pom.xml  ... (1)

.. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 90

  * - | 項番
    - | 説明
  * - | (1)
    - domainモジュールの構成を定義するPOM(Project Object Model)ファイル。
      このファイルでは、以下の定義を行う。

      * 依存ライブラリとビルド用プラグインの定義
      * jarファイルを作成するための定義

|

.. tabs::
  .. group-tab:: Java Config

    .. code-block:: console
    
      └── src
          ├── main
          │   ├── java
          │   │   └── com
          │   │       └── example
          │   │           └── project
          │   │               ├── domain  ... (2)
          │   │               │   ├── model
          │   │               │   ├── repository
          │   │               │   └── service
          │   │               └── config
          │   │                   └── app
          │   │                         ├── [artifactId]CodeListConfig.java  ... (4)
          │   │                         ├── [artifactId]DomainConfig.java  ... (5)
          │   │                         └── [artifactId]InfraConfig.java  ... (6)
          │   └── resources
          │       └── META-INF
          │           └── spring  ... (3)
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (2)
        - ドメイン層のクラスを格納するためのパッケージ。
      * - | (3)
        - Spring Frameworkのプロパティファイルを格納するディレクトリ。
      * - | (4)
        - コードリストを定義するためのBean定義ファイル。
      * - | (5)
        - ドメイン層のコンポーネントを定義するためのBean定義ファイル。
    
          このファイルには、以下のBeanを定義する。
    
          * ドメイン層のコンポーネント(Service, Repositoryなど)
          * インフラストラクチャ層のコンポーネント(インフラストラクチャ層のコンポーネントが定義されているBean定義ファイルをimportする)
          * Spring Frameworkから提供されているトランザクション管理用のコンポーネント
    
      * - | (6)
        - インフラストラクチャ層のコンポーネントを定義するためのBean定義ファイル。
    
          このファイルには、O/R MapperなどのBean定義を行う。

  .. group-tab:: XML Config

    .. code-block:: console
    
      └── src
          ├── main
          │   ├── java
          │   │   └── com
          │   │       └── example
          │   │           └── project
          │   │               └── domain  ... (2)
          │   │                   ├── model
          │   │                   ├── repository
          │   │                   └── service
          │   └── resources
          │       └── META-INF
          │           └── spring  ... (3)
          │               ├── [artifactId]-codelist.xml  ... (4)
          │               ├── [artifactId]-domain.xml  ... (5)
          │               └── [artifactId]-infra.xml  ... (6)
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (2)
        - ドメイン層のクラスを格納するためのパッケージ。
      * - | (3)
        - Spring FrameworkのBean定義ファイルとプロパティファイルを格納するディレクトリ。
      * - | (4)
        - コードリストを定義するためのBean定義ファイル。
      * - | (5)
        - ドメイン層のコンポーネントを定義するためのBean定義ファイル。
    
          このファイルには、以下のBeanを定義する。
    
          * ドメイン層のコンポーネント(Service, Repositoryなど)
          * インフラストラクチャ層のコンポーネント(インフラストラクチャ層のコンポーネントが定義されているBean定義ファイルをimportする)
          * Spring Frameworkから提供されているトランザクション管理用のコンポーネント
    
      * - | (6)
        - インフラストラクチャ層のコンポーネントを定義するためのBean定義ファイル。
    
          このファイルには、O/R MapperなどのBean定義を行う。

|

.. tabs::
  .. group-tab:: Java Config

    .. code-block:: console
    
      └── test
          └── java
              └── com
                  └── example
                      └── project
                          ├── domain
                          │   ├── repository
                          │   └── service
                          └── config
                              └── TestContextConfig.java  ... (7)
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (7)
        - ドメイン層のユニットテスト用のコンポーネントを定義するためのBean定義ファイル。

  .. group-tab:: XML Config

    .. code-block:: console
    
        └── test
            ├── java
            │   └── com
            │       └── example
            │           └── project
            │               └── domain
            │                   ├── repository
            │                   └── service
            └── resources
                └── test-context.xml  ... (7)
    
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (7)
        - ドメイン層のユニットテスト用のコンポーネントを定義するためのBean定義ファイル。

|

\ **MyBatis3用のプロジェクトを作成した場合**\

.. tabs::
  .. group-tab:: Java Config

    .. code-block:: console
    
      └── src
          ├── main
          │   ├── java
          │   │   └── com
          │   │       └── example
          │   │           └── project
          │   │               ├── domain
          │   │               └── config
          │   │                   └── mybatis
          │   │                       └── MybatisConfig.java  ... (9)
          │   └── resources
          │       ├── META-INF
          │       │   └── spring
         (...)
          │       └── com
          │           └── example
          │               └── project
          │                   └── domain
          │                       └── repository  ... (10)
          │                           └── sample
          │                               └── SampleRepository.xml  ... (11)
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (8)
        - MyBatis3の設定ファイルを格納するディレクトリ。
      * - | (9)
        - MyBatis3の設定ファイル。
    
          作成時点では、いくつかの推奨設定が定義されている。
      * - | (10)
        - MyBatis3のMapperファイルを格納するディレクトリ。
      * - | (11)
        - | MyBatis3のMapperファイルのサンプルファイル。
    
          | Maven Archetypeで作成したプロジェクトでは、サンプル実装がコメントアウトされた状態になっている。
          | \ **実際のアプリケーション開発で使用することは想定していないので、基本的にはこのファイルは削除すること。**\

  .. group-tab:: XML Config

    .. code-block:: console
    
      └── src
          ├── main
          │   ├── java
         (...)
          │   └── resources
          │       ├── META-INF
          │       │   ├── mybatis  ... (8)
          │       │   │   └── mybatis-config.xml  ... (9)
          │       │   └── spring
         (...)
          │       └── com
          │           └── example
          │               └── project
          │                   └── domain
          │                       └── repository  ... (10)
          │                           └── sample
          │                               └── SampleRepository.xml  ... (11)
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (8)
        - MyBatis3の設定ファイルを格納するディレクトリ。
      * - | (9)
        - MyBatis3の設定ファイル。
    
          作成時点では、いくつかの推奨設定が定義されている。
      * - | (10)
        - MyBatis3のMapperファイルを格納するディレクトリ。
      * - | (11)
        - | MyBatis3のMapperファイルのサンプルファイル。
    
          | Maven Archetypeで作成したプロジェクトでは、サンプル実装がコメントアウトされた状態になっている。
          | \ **実際のアプリケーション開発で使用することは想定していないので、基本的にはこのファイルは削除すること。**\

|

.. _CreateWebApplicationProjectConfigurationEnv:

envモジュールの構成
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

環境依存性をもつ設定ファイルを管理するモジュールの構成について説明する。

.. code-block:: console

  [artifactId]-env
      ├── configs  ... (1)
      │   ├── production-server  ... (2)
      │   │   ├── java
      │   │   └── resources
      │   └── test-server
      │       ├── java
      │       └── resources
      ├── pom.xml  ... (3)

.. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 90

  * - | 項番
    - | 説明
  * - | (1)
    - 環境依存する設定ファイルを管理するためのディレクトリ。

      環境毎にサブディレクトリを作成し、環境依存する設定ファイルを管理する。
  * - | (2)
    - 環境毎の設定ファイルを管理するためのディレクトリ。

      作成時点では、最もシンプルな構成として、以下のディレクトリ(雛形のディレクトリ)が用意されている。

      * production-server (商用環境向けの設定ファイルを格納するディレクトリ)
      * test-server (テスト環境向けの設定ファイルを格納するディレクトリ)

  * - | (3)
    - envモジュールの構成を定義するPOM(Project Object Model)ファイル。
      このファイルでは、以下の定義を行う。

      * 依存ライブラリとビルド用プラグインの定義
      * 環境毎のjarファイルを作成するためのProfileの定義

|

.. tabs::
  .. group-tab:: Java Config

    .. code-block:: console
    
      └── src
          └── main
              ├── java
              │   └── com
              │       └── example
              │           └── project
              │               └── config
              │                   └── app
              │                       └── [artifactId]EnvConfig.java  ... (5)
              └── resources  ... (4)
                  ├── META-INF
                  │   └── spring
                  │       └── [artifactId]-infra.properties  ... (6)
                  ├── database  ... (7)
                  │   ├── H2-dataload.sql
                  │   └── H2-schema.sql
                  └── logback.xml  ... (8)
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (4)
        - 開発用の設定ファイルを管理するためのディレクトリ。
      * - | (5)
        - 環境依存するコンポーネントを定義するBean定義ファイル。
    
          このファイルには、以下のBeanを定義する。
    
          * データソース
          * 共通ライブラリから提供している\ ``ClockFactory``\ (環境によって異なる実装を使用する場合)
          * Spring Frameworkから提供されているトランザクション管理用のコンポーネント (環境によって異なる実装を使用する場合)
    
      * - | (6)
        - 環境依存する設定値を定義するプロパティファイル。
    
          作成時点では、データソースの設定値(接続情報とコネクションプールの設定値)が定義されている。
      * - | (7)
        - | インメモリデータベース(H2 Database)をセットアップするためのSQLを格納するディレクトリ。
    
          | このディレクトリは、ちょっとした動作検証を行う時のために用意しているディレクトリである。
          | \ **実際のアプリケーション開発で使用することは想定していないので、基本的にはこのディレクトリは削除すること。**\
      * - | (8)
        - Logback(ログ出力)の設定ファイル。
    
          ログ出力については、「\ :doc:`../ArchitectureInDetail/GeneralFuncDetail/Logging`\ 」を参照されたい。

  .. group-tab:: XML Config

    .. code-block:: console
    
      └── src
          └── main
              └── resources  ... (4)
                  ├── META-INF
                  │   └── spring
                  │       ├── [artifactId]-env.xml  ... (5)
                  │       └── [artifactId]-infra.properties  ... (6)
                  ├── database  ... (7)
                  │   ├── H2-dataload.sql
                  │   └── H2-schema.sql
                  └── logback.xml  ... (8)
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (4)
        - 開発用の設定ファイルを管理するためのディレクトリ。
      * - | (5)
        - 環境依存するコンポーネントを定義するBean定義ファイル。
    
          このファイルには、以下のBeanを定義する。
    
          * データソース
          * 共通ライブラリから提供している\ ``ClockFactory``\ (環境によって異なる実装を使用する場合)
          * Spring Frameworkから提供されているトランザクション管理用のコンポーネント (環境によって異なる実装を使用する場合)
    
      * - | (6)
        - 環境依存する設定値を定義するプロパティファイル。
    
          作成時点では、データソースの設定値(接続情報とコネクションプールの設定値)が定義されている。
      * - | (7)
        - | インメモリデータベース(H2 Database)をセットアップするためのSQLを格納するディレクトリ。
    
          | このディレクトリは、ちょっとした動作検証を行う時のために用意しているディレクトリである。
          | \ **実際のアプリケーション開発で使用することは想定していないので、基本的にはこのディレクトリは削除すること。**\
      * - | (8)
        - Logback(ログ出力)の設定ファイル。
    
          ログ出力については、「\ :doc:`../ArchitectureInDetail/GeneralFuncDetail/Logging`\ 」を参照されたい。

|

.. _CreateWebApplicationProjectConfigurationInitdb:

initdbモジュールの構成
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

データベースを初期化するためのSQLファイルを管理するモジュールの構成について説明する。

.. code-block:: console

  [artifactId]-initdb
      ├── pom.xml  ... (1)
      └── src
          └── main
              └── sqls  ... (2)

.. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 90

  * - | 項番
    - | 説明
  * - | (1)
    - initdbモジュールの構成を定義するPOM(Project Object Model)ファイル。
      このファイルでは、以下の定義を行う。

      * ビルド用プラグイン(\ `SQL Maven Plugin <https://www.mojohaus.org/sql-maven-plugin/>`_\ )の定義

      作成時点では、PostgreSQL用の雛形設定が定義されている。
  * - | (2)
    - データベースを初期化するためのSQLファイルを格納するためのディレクトリ。

      | 作成時点では、空のディレクトリである。
      | 作成例については、\ `サンプルアプリケーションのinitdbプロジェクト <https://github.com/Macchinetta/atrs-thymeleaf/tree/1.11.0.RELEASE/atrs-initdb/src/sqls/integration-test-postgres>`_\ を参照されたい。

.. note::

  \ `SQL Maven Plugin <https://www.mojohaus.org/sql-maven-plugin/>`_\ の\ `sql:execute <https://www.mojohaus.org/sql-maven-plugin/execute-mojo.html>`_\ を使用して、SQLを実行できる。

    .. code-block:: console

      mvn sql:execute

|

.. _CreateWebApplicationProjectConfigurationSelenium:

seleniumモジュールの構成
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Seleniumを使用したE2E(End To End)テスト用のコンポーネントを管理するモジュールの構成について説明する。

.. tabs::
  .. group-tab:: Java Config

    .. code-block:: console
    
      [artifactId]-selenium
          ├── pom.xml  ... (1)
          └── src
              └── test  ... (2)
                  ├── java
                  │   └── com
                  │       └── example
                  │           ├── project
                  │           │   └── selenium
                  │           │       └── welcome
                  │           │           └── HelloIT.java  ... (3)
                  │           └── config
                  │               └── SeleniumContextConfig.java  ... (5)
                  └── resources
                      └── META-INF
                          └── spring
                              └── selenium.properties  ... (4)
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (1)
        - seleniumモジュールの構成を定義するPOM(Project Object Model)ファイル。
    
          このファイルでは、以下の定義を行う。
    
          * 依存ライブラリとビルド用プラグインの定義
          * jarファイルを作成するための定義
    
      * - | (2)
        - テスト用のコンポーネントと設定ファイルを格納するディレクトリ。
    
          作成例については、\ `共通ライブラリのテストアプリケーションのseleniumプロジェクト <https://github.com/terasolunaorg/terasoluna-gfw-functionaltest/tree/5.10.0.RELEASE/terasoluna-gfw-functionaltest-selenium>`_\ を参照されたい。
    
      * - | (3)
        - Selenium WebDriverを使用したサンプルテストクラス。
    
          作成時点では、Welcomeページのタイトルを検証するテストケースが実装されている。
    
      * - | (4)
        - テストで使用する設定値を定義するプロパティファイル。
    
          作成時点では、アプリケーションサーバのURLは\ ``http://localhost:8080/``\ である。
    
      * - | (5)
        - テスト用のコンポーネントを定義するためのBean定義ファイル。
    
          作成時点では、サンプルのテストを実行するために必要な設定がされている。

  .. group-tab:: XML Config

    .. code-block:: console
    
      [artifactId]-selenium
          ├── pom.xml  ... (1)
          └── src
              └── test  ... (2)
                  ├── java
                  │   └── com
                  │       └── example
                  │           └── project
                  │               └── selenium
                  │                   └── welcome
                  │                       └── HelloIT.java  ... (3)
                  └── resources
                      └── META-INF
                          └── spring
                              ├── selenium.properties  ... (4)
                              └── seleniumContext.xml  ... (5)
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
    
      * - | 項番
        - | 説明
      * - | (1)
        - seleniumモジュールの構成を定義するPOM(Project Object Model)ファイル。
    
          このファイルでは、以下の定義を行う。
    
          * 依存ライブラリとビルド用プラグインの定義
          * jarファイルを作成するための定義
    
      * - | (2)
        - テスト用のコンポーネントと設定ファイルを格納するディレクトリ。
    
          作成例については、\ `共通ライブラリのテストアプリケーションのseleniumプロジェクト <https://github.com/terasolunaorg/terasoluna-gfw-functionaltest/tree/5.10.0.RELEASE/terasoluna-gfw-functionaltest-selenium>`_\ を参照されたい。
    
      * - | (3)
        - Selenium WebDriverを使用したサンプルテストクラス。
    
          作成時点では、Welcomeページのタイトルを検証するテストケースが実装されている。
    
      * - | (4)
        - テストで使用する設定値を定義するプロパティファイル。
    
          作成時点では、アプリケーションサーバのURLは\ ``http://localhost:8080/``\ である。
    
      * - | (5)
        - テスト用のコンポーネントを定義するためのBean定義ファイル。
    
          作成時点では、サンプルのテストを実行するために必要な設定がされている。

|

.. _CreateWebApplicationProjectAppendix:

Appendix
--------------------------------------------------------------------------------

.. _CreateWebApplicationProjectAppendixProjectHierarchicalStructure:

プロジェクトの階層構造
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Maven Archetypeで作成したプロジェクトのプロジェクト階層の構造を以下に示す。

.. figure:: images_CreateWebApplicationProject/CreateWebApplicationProjectHierarchicalStructure.png
  :width: 100%

.. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 10 90
  :class: longtable

  * - | 項番
    - | 説明
  * - | (1)
    - Maven Archetypeで作成したプロジェクト。

      Maven Archetypeで作成したプロジェクトはマルチモジュール構成となっており、親プロジェクトと各サブモジュールは相互参照の関係になっている。

      version 1.11.0.RELEASE用のMaven Archetypeで作成したプロジェクトでは、親プロジェクトとして「org.terasoluna.gfw:terasoluna-gfw-parent:5.10.0.RELEASE」を指定している。
  * - | (2)
    - TERASOLUNA Server Framework for Java (5.x) Parentプロジェクト。

      TERASOLUNA Server Framework for Java (5.x) Parentプロジェクトでは、

      * ビルド用のプラグインの設定
      * Spring Boot経由で管理されているライブラリのカスタマイズ(バージョンの調整)
      * Spring Bootで管理されていない推奨ライブラリのバージョン管理

      を行っている。

      なお、Spring Boot経由で依存ライブラリのバージョンを管理するために、本プロジェクトの\ ``<dependencyManagement>``\ に「Spring Boot Dependencies」をインポートしている。

      利用しているSpring Bootのバージョンは\ :ref:`frameworkstack_using_oss_version`\ 参照のこと。
  * - | (3)
    - Spring Boot Dependenciesプロジェクト。

.. tip::

  version 1.6.1.RELEASEより、Spring Bootの\ ``<dependencyManagement>``\ をインポートする構成に変更しており、推奨ライブラリのバージョン管理をSpring Bootに委譲するスタイルを採用している。

.. warning::

  version 1.6.1.RELEASEより、Spring Bootの\ ``<dependencyManagement>``\ をインポートする構成に変更したため、子プロジェクトからライブラリのバージョンを管理するためのプロパティにアクセスする事が出来なくなっている。

  そのため、子プロジェクト側でプロパティ値を参照又は上書きしている場合は、version 1.0.xからバージョンアップする際にpomファイルの修正が必要になる。

  なお、Spring Bootで管理していない推奨ライブラリ(Macchinetta Server Framework (1.x)独自の推奨ライブラリ)については、従来通りバージョンを管理するためのプロパティにアクセスする事ができる。

|

.. _CreateWebApplicationProjectAppendixApplicationContext:

アプリケーションコンテキストの構成とBean定義ファイルの関係
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Spring Frameworkのアプリケーションコンテキスト(DIコンテナ)の構成とBean定義ファイルの関係を以下に示す。

.. figure:: images_CreateWebApplicationProject/CreateWebApplicationProjectApplicationContext.png
  :width: 100%

.. tabs::
  .. group-tab:: Java Config

    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
      :class: longtable
    
      * - | 項番
        - | 説明
      * - | (1)
        - Webアプリケーション用のアプリケーションコンテキスト。
    
          上記図で示す通り、

          * [artifactId]-web/src/main/java/com/example/project/config/app/ApplicationContextConfig.java
          * [artifactId]-domain/src/main/java/com/example/project/config/app/[artifactId]DomainConfig.java
          * [artifactId]-domain/src/main/java/com/example/project/config/app/[artifactId]InfraConfig.java
          * [artifactId]-env/src/main/java/com/example/project/config/app/[artifactId]EnvConfig.java    
          * [artifactId]-domain/src/main/java/com/example/project/config/app/[artifactId]CodelistConfig.java
          * [artifactId]-web/src/main/java/com/example/project/config/app/SpringSecurityConfig.java

          で定義したコンポーネントがWebアプリケーション用のアプリケーションコンテキスト(DIコンテナ)に登録される。
    
          Webアプリケーション用のアプリケーションコンテキストに登録されているコンポーネントは、各\ ``DispatcherServlet``\ 用のアプリケーションコンテキストから参照する事ができる仕組みとなっている。
      * - | (2)
        - \ ``DispatcherServlet``\ 用のアプリケーションコンテキスト。
    
          上記図で示す通り、

          * [artifactId]-web/src/main/java/com/example/project/config/web/SpringMvcConfig.java
    
          で定義したコンポーネントが\ ``DispatcherServlet``\ 用のアプリケーションコンテキスト(DIコンテナ)に登録される。
    
          \ ``DispatcherServlet``\ 用のアプリケーションコンテキストに存在しないコンポーネントは、Webアプリケーション用のアプリケーションコンテキスト(親コンテキスト)を参照して取得する仕組みになっているため、ドメイン層のコンポーネントをアプリケーション層のコンポーネントに対してインジェクションする事ができる。

  .. group-tab:: XML Config
    
    .. tabularcolumns:: |p{0.10\linewidth}|p{0.90\linewidth}|
    .. list-table::
      :header-rows: 1
      :widths: 10 90
      :class: longtable
    
      * - | 項番
        - | 説明
      * - | (1)
        - Webアプリケーション用のアプリケーションコンテキスト。
    
          上記図で示す通り、

          * [artifactId]-web/src/main/resources/META-INF/spring/applicationContext.xml
          * [artifactId]-domain/src/main/resources/META-INF/spring/[artifactId]-domain.xml
          * [artifactId]-domain/src/main/resources/META-INF/spring/[artifactId]-infra.xml
          * [artifactId]-env/src/main/resources/META-INF/spring/[artifactId]-env.xml
          * [artifactId]-domain/src/main/resources/META-INF/spring/[artifactId]-codelist.xml
          * [artifactId]-web/src/main/resources/META-INF/spring/spring-security.xml

          で定義したコンポーネントがWebアプリケーション用のアプリケーションコンテキスト(DIコンテナ)に登録される。
    
          Webアプリケーション用のアプリケーションコンテキストに登録されているコンポーネントは、各\ ``DispatcherServlet``\ 用のアプリケーションコンテキストから参照する事ができる仕組みとなっている。
      * - | (2)
        - \ ``DispatcherServlet``\ 用のアプリケーションコンテキスト。
    
          上記図で示す通り、
    
          * [artifactId]-web/src/main/resources/META-INF/spring/spring-mvc.xml
    
          で定義したコンポーネントが\ ``DispatcherServlet``\ 用のアプリケーションコンテキスト(DIコンテナ)に登録される。
    
          \ ``DispatcherServlet``\ 用のアプリケーションコンテキストに存在しないコンポーネントは、Webアプリケーション用のアプリケーションコンテキスト(親コンテキスト)を参照して取得する仕組みになっているため、ドメイン層のコンポーネントをアプリケーション層のコンポーネントに対してインジェクションする事ができる。

.. note:: \ **同じコンポーネントを両方のアプリケーションコンテキストに登録した時の動作について**\

  Webアプリケーション用のアプリケーションコンテキストと\ ``DispatcherServlet``\ 用のアプリケーションコンテキストの両方に同じコンポーネントが登録されている場合は、同じアプリケーションコンテキスト(\ ``DispatcherServlet``\ 用のアプリケーションコンテキスト)内に登録されているコンポーネントがインジェクションされる点を補足しておく。

  特に、ドメイン層のコンポーネント(ServiceやRepositoryなど)を\ ``DispatcherServlet``\ 用のアプリケーションコンテキストに登録しないように注意する必要である。

  ドメイン層のコンポーネントを\ ``DispatcherServlet``\ 用のアプリケーションコンテキストに登録してしまうと、トランザクション制御を行うコンポーネント(AOP)が有効にならないため、データベースへの操作がコミットされない不具合が発生してしまう。

  なお、Maven Archetypeで作成したプロジェクトでは、上記のような現象は発生しないように設定が行われている。設定の追加又は変更を行う場合は、注意してほしい。

|

オフライン環境におけるアプリケーション開発
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

| 「\ :ref:`CreateWebApplicationProject`\ 」では、マルチプロジェクト構成の開発プロジェクトを、\ `Maven Archetype Plugin <https://maven.apache.org/archetype/maven-archetype-plugin/>`_\ の\ `archetype:generate <https://maven.apache.org/archetype/maven-archetype-plugin/generate-mojo.html>`_\ を使用して作成する方法について述べた。
| Mavenはオンライン環境での動作が前提であるが、以下にオフライン環境でも使用できるようにする方法について述べる。
|
| オフライン環境でプロジェクト開発を続けるためには、開発に必要となるライブラリやプラグイン等のファイルを事前にコピーする必要がある。
| 以下の作業は\ **オンライン環境**\ で行うこと。
|
| 開発プロジェクトのルートディレクトリへ移動する。
| ここでは「\ :ref:`CreateWebApplicationProject`\ 」で作成したプロジェクトを例に説明をする。

.. code-block:: console

  cd C:\work\todo

|

| プロジェクト開発に必要であるライブラリやプラグイン等のファイルをコピーする。
| \ `Maven Archetype Plugin <https://maven.apache.org/archetype/maven-archetype-plugin/>`_\ の\ `dependency:go-offline <https://maven.apache.org/plugins/maven-dependency-plugin/go-offline-mojo.html>`_\ を実行することでコピーする。
| なお、\ ``dependency:go-offline``\ のみではマルチプロジェクトの依存関係を解決できずビルドに失敗するため、\ ``package``\ を指定している。

.. code-block:: console

  mvn package dependency:go-offline -Dmaven.repo.local=repository

.. tabularcolumns:: |p{0.25\linewidth}|p{0.75\linewidth}|
.. list-table::
  :header-rows: 1
  :widths: 25 75

  * - パラメータ
    - 説明
  * - | \--Dmaven.repo.local
    - コピー先を指定する。
      コピー先が存在しない場合は新たに作成される。
      今回はコピー先をrepositoryと指定している。

|

ビルドが成功した場合、以下のようなログが出力される。

.. code-block:: console

  (omitted)
  [INFO] ------------------------------------------------------------------------
  [INFO] Reactor Summary for Macchinetta Server Framework (1.x) Web Blank Multi Project (JavaConfig)(JSP)(MyBatis3) 1.0.0-SNAPSHOT:
  [INFO]
  [INFO] Macchinetta Server Framework (1.x) Web Blank Mult (JavaConfig)(JSP)(MyBatis3) SUCCESS [01:00 min]
  [INFO] todo-env ........................................... SUCCESS [01:01 min]
  [INFO] todo-domain ........................................ SUCCESS [ 26.306 s]
  [INFO] todo-web ........................................... SUCCESS [ 17.948 s]
  [INFO] todo-initdb ........................................ SUCCESS [  8.104 s]
  [INFO] todo-selenium ...................................... SUCCESS [ 52.715 s]
  [INFO] ------------------------------------------------------------------------
  [INFO] BUILD SUCCESS
  [INFO] ------------------------------------------------------------------------
  [INFO] Total time:  04:07 min
  [INFO] Finished at: 2023-07-11T15:38:18+09:00
  [INFO] ------------------------------------------------------------------------

|

| 以上で、プロジェクト開発に必要なライブラリやプラグイン等のファイルをコピーした。このrepositoryをオフライン環境マシンの\ ``${HOME}/.m2``\ へコピーすることで、作業は完了となる。
| オンライン環境で一度も実行していない処理をオフライン環境で実行すると、必要なライブラリやプラグイン等のファイルを取得できず処理に失敗するが、コピーを行ったことにより、オフライン環境へ移行した場合においても継続して開発を進めることが可能となる。

.. warning:: \ **オフライン環境での開発における注意点**\

  オフライン環境では新規に依存関係をインターネットから取得することが不可能となるため、POM(Project Object Model)ファイルを編集しないこと。

  POMファイルに編集を加える場合は、再度オンライン環境へ戻る必要がある。

.. raw:: latex

   \newpage