Na especificação Servlet 3.0, os elementos <injection-target> de uma referência de recurso definida em um arquivo web-fragment.xml serão incluídos no arquivo web.xml pai somente se a definição de referência de recurso web.xml com o mesmo nome não tiver elementos <injection-target>. A especificação Servlet 3.1 esclarece que para uma referência de recurso com o mesmo nome, todos os elementos <injection-target> nos descritores web-fragment.xml são incluídos na lista de descritores web.xml pai dos elementos <injection-target>. O recurso do Servlet 3.1 pode mudar o comportamento do aplicativo existente, ativando destinos de injeção que foram excluídos anteriormente do arquivo web.xml.
Essa regra sinalizará o elemento <injection-target> no arquivo web-fragment.xml se o arquivo web.xml contiver um elemento <injection-target> dentro de um elemento <resource-ref> definido com o mesmo nome do elemento <resource-ref> no arquivo web-fragment.xml.
Os exemplos a seguir demonstram a mudança de comportamento quando você usa uma combinação de um arquivo web.xml e um arquivo web-fragment.xml:
web.xml:
<resource-ref> <res-ref-name>ReferenceName</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> <res-sharing-scope>Shareable</res-sharing-scope> <injection-target> <injection-target-class>Class1</injection-target-class> <injection-target-name>Resource1</injection-target-name> </injection-target> </resource-ref> |
web-fragment.xml:
<resource-ref> <res-ref-name>ReferenceName</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> <res-sharing-scope>Shareable</res-sharing-scope> <injection-target> <injection-target-class>Class2</injection-target-class> <injection-target-name>Resource2</injection-target-name> </injection-target> </resource-ref> |
No Servlet 3.0, o resultado combinado ignora o destino da injeção para Class2:
<resource-ref> <res-ref-name>ReferenceName</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> <res-sharing-scope>Shareable</res-sharing-scope> <injection-target> <injection-target-class>Class1</injection-target-class> <injection-target-name>Resource1</injection-target-name> </injection-target> </resource-ref> |
No Servlet 3.1, o resultado combinado usa o destino da injeção para Class2:
<resource-ref> <res-ref-name>ReferenceName</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> <res-sharing-scope>Shareable</res-sharing-scope> <injection-target> <injection-target-class>Class1</injection-target-class> <injection-target-name>Resource1</injection-target-name> </injection-target> <injection-target> <injection-target-class>Class2</injection-target-class> <injection-target-name>Resource2</injection-target-name> </injection-target> </resource-ref> |
Para mais informações sobre mudanças de comportamento do Servlet 3.1, veja o recurso a seguir: Mudanças de comportamento do Servlet 3.1.