Questa regola contrassegna gli elementi Context <Environment> trovati nel file META-INF/context.xml che devono essere trasformati negli elementi <env-entry> nel file WEB-INF/web.xml.
Apache Tomcat consente di definire gli elementi Context <Environment> in questi percorsi:
Poiché lo strumento di migrazione potrebbe non avere accesso alla directory di configurazione Tomcat, contrassegna solo Context <Environment> nel file META-INF/context.xml. Le informazioni Context <Environment> definite in altri percorsi possono essere copiate nel file META-INF/context.xml in modo che lo strumento possa elaborarle.
Se esiste un WEB-INF/web.xml nel progetto web:
gli elementi Context <Environment> verranno contrassegnati alle seguenti condizioni:
Nello scanner di origine è disponibile una correzione rapida per questa regola. La correzione rapida aggiunge un nuovo elemento <env-entry> nel file web.xml che rappresenta l'elemento Context <Environment> se non esiste già nel file web.xml. Se la voce esiste, verrà aggiornata.
Se WEB-INF/web.xml non esiste:
verranno contrassegnati tutti gli elementi Context <Environment>.
La correzione rapida creerà un file WEB-INF/web.xml che include gli elementi <env-entry> appropriati se il progetto web p a livello Java EE 5 o successivo. La correzione rapida riporterà un errrore se il progetto web è a livello di J2EE 1.4 o inferiore.
Ad esempio, considerare un file META-INF/context.xml con il seguente contenuto:|
<Environment 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="new 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"/> |
con il seguente file web.xml nell'applicazione:
|
<env-entry> <description>Trigger because of different value</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>Trigger because of different type</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>will not Trigger because of override set to 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> |
Una volta che è stata applicata la correzione rapida, il file web.xml verrà aggiornato per contenere:
|
<env-entry> <description>Trigger because of different value</description> <env-entry-name>contextEnvString_1</env-entry-name> <env-entry-type>java.lang.String</env-entry-type> <env-entry-value>new Value</env-entry-value> </env-entry> <env-entry> <description>Trigger because of different type</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>will not Trigger because of override set to 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>Trigger becasue it does not exist</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> |