Использовать файлы описания Java EE для определения ссылок на среду

Это правило помечает Context <Environment> элементы, найденные в файле META-INF/context.xml , который должен быть преобразован в <env-entry> элементы в ФайлWEB-INF/web.xml .

Apache Tomcat allows Context <Environment> элементы, которые должны быть определены в следующих положениях:

Поскольку инструмент миграции может не иметь доступа к каталогу конфигурации Tomcat , он только помечает Context <Environment> в META-INF/context.xml . Context <Environment> Информация, определенная в других положениях, может быть скопирована в файл META-INF/context.xml , чтобы его можно было обработать инструментом.

Если файл WEB-INF/web.xml существует в веб-проекте:

Context <Environment> элементы будут помечены под любым из следующих условий:

Добавить новый <env-entry> в файле web.xml , который представляет Context <Environment> элемент, если он еще не существует в Файлweb.xml . Если запись существует, она будет обновлена.

Если файл WEB-INF/web.xml не существует:

Все Context <Environment> Элементы будут помечены.

Создайте WEB-INF/web.xml файл который включает в себя соответствующие <env-entry> элементы, если веб-проект находится на уровне Java EE 5 или выше. Автоматическое исправление сообщит об ошибке, если веб-проект находится на J2EE 1.4 или ниже.

Пример: существует файл META-INF/context.xml со следующим содержимым:
< span class="Code"> < Среда
description="Trigger because it does not exist"
name="newEntry"
override="false"
type= "java.lang.String" value= "abc123" />
<Environment
description="Trigger because of different value"
name="contextEnvString_1"
override="false"
type="java.lang.String"
value = "новое Значение " />
<Environment
description="Trigger because of different type"
name="contextEnvString_2"
override="false"
type="java.lang.Integer"
value="123 " />
<Environment
description="will not Trigger because of override set to true."
name="contextEnvString_3"
override="true"
type="java.lang.Integer"
value="123 " />

со следующим файлом web.xml в приложении:

< span class="Code"> < env-entry>
<description>Триггер из-за другого значения</description>
<env-entry-name>contextEnvString_1</env-entry-name>
<env-entry-type>java.lang.String</env-entry-type>
<env-entry-value>oldValue</env-entry-value>
</env-entry>

< env-entry>
<description>Триггер из-за другого типа</description>
<env-entry-name>contextEnvString_2</env-entry-name>
<env-entry-type>java.lang.String</env-entry-type>
<env-entry-value>123</env-entry-value>
</env-entry>

< env-entry>
<description>не будет триггером, поскольку для переопределения задано значение true.</description>
<env-entry-name>contextEnvString_3</env-entry-name>
<env-entry-type>java.lang.Integer</env-entry-type>
<env-entry-value>123456789</env-entry-value>
</env-entry>

После применения автоматического исправления web.xml будет обновлен до содержать:

< span class="Code"> < env-entry>
<description>Триггер из-за другого значения</description>
<env-entry-name>contextEnvString_1</env-entry-name>
<env-entry-type>java.lang.String</env-entry-type>
<env-entry-value>новое Значение</env-entry-value>
</env-entry>

< env-entry>
<description>Триггер из-за другого типа</description>
<env-entry-name>contextEnvString_2</env-entry-name>
<env-entry-type>java.lang.Integer</env-entry-type>
<env-entry-value>123</env-entry-value>
</env-entry>

< env-entry>
<description>не будет триггером, поскольку для переопределения задано значение true.</description>
<env-entry-name>contextEnvString_3</env-entry-name>
<env-entry-type>java.lang.Integer</env-entry-type>
<env-entry-value>123456789</env-entry-value>
</env-entry>

< env-entry>
<description>Триггер becasue не существует</description>
<env-entry-name>newEntry</env-entry-name>
<env-entry-type>java.lang.String</env-entry-type>
<env-entry-value>abc123</env-entry-value>
</env-entry>