This appendix describes the standard Java EE deployment descriptor elements for WebLogic Server 12.1.3.
With Java EE annotations, the standard web.xml deployment descriptor is optional. According to the servlet 3.0 specification at http://jcp.org/en/jsr/detail?id=315, annotations can be defined on certain Web components, such as servlets, filters, listeners, and tag handlers. The annotations are used to declare dependencies on external resources. See WebLogic Annotation for Web Components.
This appendix includes the following sections:
The correct text for the namespace declaration and schema location for the web.xml file is as follows.
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
To view the schema for web.xml, go to http://www.oracle.com/webfolder/technetwork/jsc/xml/ns/javaee/web-app_3_0.xsd.
The icon element specifies the location within the Web application for a small and large image used to represent the Web application in a GUI tool. (The servlet element also has an element called the icon element, used to supply an icon to represent a servlet in a GUI tool.)
The following table describes the elements you can define within an icon element.
| Element | Required/ Optional | Description | 
|---|---|---|
| <small-icon> | Optional | Location for a small (16x16 pixel)  | 
| <large-icon> | Optional | Location for a large (32x32 pixel)  | 
The optional display-name element specifies the Web application display name, a short name that can be displayed by GUI tools.
The optional description element provides descriptive text about the Web application.
The distributable element is not used by WebLogic Server.
The optional context-param element contains the declaration of a Web application's servlet context initialization parameters.
Table A-5 context-parameter Elements
| Element | Required/Optional | Description | 
|---|---|---|
| weblogic.httpd. clientCertProxy | optional | This attribute specifies that certifications from clients of the Web application are provided in the special  This setting is useful if user authentication is performed on a proxy server—setting  A  For this reason, if you set  In addition to setting this attribute for an individual Web application, you can define this attribute: For all Web applications hosted by a server instance, on the Server > Configuration > General page in the WebLogic Server Administration Console. For all Web applications hosted by server instances in a cluster, on the Cluster > Configuration > General page. | 
The following table describes the reserved context parameters used by the Web application container, which have been deprecated and have replacements in weblogic.xml.
Table A-6 Deprecated context-param Elements
| Deprecated Parameter | Description | Replacement Element in weblogic.xml | 
|---|---|---|
| weblogic.httpd.inputCharset | Defines code set behavior for non-unicode operations. | 
 | 
| weblogic.httpd.servlet.reloadCheckSecs | Define how often WebLogic Server checks whether a servlet has been modified, and if so, reloads it. A value of -1 is never reload, 0 is always reload. The default is set to 1 second. | 
 | 
| weblogic.httpd.servlet.classpath | When this values has been set, the container appends this path to the Web application classpath. This is not a recommended method and is supported only for backward compatibility. | No replacement. Use other means such as manifest classpath or  | 
| weblogic.httpd.defaultServlet | Sets the default servlet for the Web application. This is not a recommended method and is supported only for backward compatibility. | No replacement. Instead use the  | 
The filter element defines a filter class and its initialization attributes. For more information on filters, see Configuring Filters.
The following table describes the elements you can define within a filter element.
| Element | Required/Optional | Description | 
|---|---|---|
| <icon> | Optional | Specifies the location within the Web application for a small and large image used to represent the filter in a GUI tool. Contains a small-icon and large-icon element. Currently, this element is not used by WebLogic Server. | 
| <filter-name> | Required | Defines the name of the filter, used to reference the filter definition elsewhere in the deployment descriptor. | 
| <display-name> | Optional | A short name intended to be displayed by GUI tools. | 
| <description> | Optional | A text description of the filter. | 
| <filter-class> | Required | The fully-qualified class name of the filter. | 
| <init-param> | Optional | Contains a name/value pair as an initialization attribute of the filter. Use a separate set of  | 
The following table describes the elements you can define within a filter-mapping element.
Table A-8 filter-mapping Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <dispatcher> | Optional | Indicates whether filters should be invoked under request dispatcher  Possible values include: 
 If the  For more information, see "Filters and the RequestDispatcher" in the servlet 3.0 specification at  | 
| <filter-name> | Required | The name of the filter to which you are mapping a URL pattern or servlet. This name corresponds to the name assigned in the  | 
| <url-pattern> | Required - or map by  | Describes a pattern used to resolve URLs. The portion of the URL after the  Example patterns: /soda/grape/* /foo/* /contents *.foo The URL must follow the rules specified in the servlet 3.0 specification. | 
| <servlet> | Required - or map by  | The name of a servlet which, if called, causes this filter to execute. | 
Define an application listener using the listener element.
| Element | Required/Optional | Description | 
|---|---|---|
| <listener-class> | Optional | Name of the class that responds to a Web application event. | 
For more information, see Configuring an Event Listener Class.
The servlet element contains the declarative data of a servlet.
If a jsp-file is specified and the <load-on-startup> element is present, then the JSP is precompiled and loaded when WebLogic Server starts.
The following table describes the elements you can define within a servlet element.
| Element | Required/Optional | Description | 
|---|---|---|
| <icon> | Optional | Location within the Web application for a small and large image used to represent the servlet in a GUI tool. Contains a small-icon and large-icon element. Currently, this element is not used by WebLogic Server. | 
| <servlet-name> | Required | Defines the canonical name of the servlet, used to reference the servlet definition elsewhere in the deployment descriptor. | 
| <display-name> | Optional | A short name intended to be displayed by GUI tools. | 
| <description> | Optional | A text description of the servlet. | 
| <servlet-class> | Optional | The fully-qualified class name of the servlet. As of servlet 3.0,  | 
| <jsp-file> | Optional | The full path to a JSP file within the Web application, relative to the Web application root directory. As of servlet 3.0,  | 
| <init-param> | Optional | Contains a name/value pair as an initialization attribute of the servlet. Use a separate set of  | 
| <load-on-startup> | Optional | WebLogic Server initializes this servlet when WebLogic Server starts up. The optional content of this element must be a positive integer indicating the order in which the servlet should be loaded. Lower integers are loaded before higher integers. If no value is specified, or if the value specified is not a positive integer, WebLogic Server can load the servlet in any order during application startup. | 
| <run-as> | Optional | Specifies the run-as identity to be used for the execution of the Web application. It contains an optional description and the name of a security role. | 
| <security-role- ref> | Optional | Used to link a security role name defined by  | 
This is an element within the servlet.
The icon element specifies the location within the Web application for small and large images used to represent the servlet in a GUI tool.
The following table describes the elements you can define within an icon element.
| Element | Required/Optional | Description | 
|---|---|---|
| <small-icon> | Optional | Specifies the location within the Web application for a small (16x16 pixel)  Currently, this element is not used by WebLogic Server. | 
| <large-icon> | Optional | Specifies the location within the Web application for a small (32x32 pixel)  Currently, this element is not used by WebLogic Server. | 
This is an element within the servlet.
The optional init-param element contains a name/value pair as an initialization attribute of the servlet. Use a separate set of init-param tags for each attribute.
You can access these attributes with the javax.servlet.ServletConfig.getInitParameter() method.
The following table describes the elements you can define within a init-param element.
This is an element within the servlet.
The security-role-ref element links a security role name defined by <security-role> to an alternative role name that is hard-coded in the servlet logic. This extra layer of abstraction allows the servlet to be configured at deployment without changing servlet code.
The following table describes the elements you can define within a security-role-ref element.
Table A-13 security-role-ref Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <description> | Optional | Text description of the role. | 
| <role-name> | Required | Defines the name of the security role or principal that is used in the servlet code. | 
| <role-link> | Required | Defines the name of the security role that is defined in a  | 
The servlet-mapping element defines a mapping between a servlet and a URL pattern.
The following table describes the elements you can define within a servlet-mapping element.
Table A-14 servlet-mapping Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <servlet-name> | Required | The name of the servlet to which you are mapping a URL pattern. This name corresponds to the name you assigned a servlet in a  | 
| <url-pattern> | Required | Describes a pattern used to resolve URLs. The portion of the URL after the  Example patterns: /soda/grape/* /foo/* /contents *.foo The URL must follow the rules specified in the servlet 3.0 specification. For additional examples of servlet mapping, see Servlet Mapping. | 
The session-config element defines the session attributes for this Web application.
The following table describes the element you can define within a session-config element.
Table A-15 session-config Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <session-timeout> | Optional | The number of minutes after which sessions in this Web application expire. The value set in this element overrides the value set in the  Default value: 60 Maximum value: Integer.MAX_VALUE ÷ 60 Special values: -1 = Sessions do not timeout. The value set in  For more information, see session-descriptor. | 
The mime-mapping element defines a mapping between an extension and a mime type.
The following table describes the elements you can define within a mime-mapping element.
The optional welcome-file-list element contains an ordered list of welcome-file elements.
When the URL request is a directory name, WebLogic Server serves the first file specified in this element. If that file is not found, the server then tries the next file in the list.
For more information, see Configuring Welcome Files.
The following table describes the element you can define within a welcome-file-list element.
The optional error-page element specifies a mapping between an error code or exception type to the path of a resource in the Web application.
When an error occurs—while WebLogic Server is responding to an HTTP request, or as a result of a Java exception—WebLogic Server returns an HTML page that displays either the HTTP error code or a page containing the Java error message. You can define your own HTML page to be displayed in place of these default error pages or in response to a Java exception.
For more information, see Customizing HTTP Error Responses.
The following table describes the elements you can define within an error-page element.
Note:
Define either an<error-code> or an <exception-type> but not both.Table A-18 error-page Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <error-code> | Optional | A valid HTTP error code, for example,  | 
| <exception-type> | Optional | A fully-qualified class name of a Java exception type, for example,  | 
| <location> | Required | The location of the resource to display in response to the error. For example,  | 
The jsp-config element is used to provide global configuration information for the JSP files in a Web application. It has two sub-elements, taglib and jsp-property-group.
The following table describes the elements you can define within a jsp-config element.
Table A-19 jsp-config Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <taglib> | Optional | Provides information on a tag library that is used by a JSP page within the Web application. | 
| <jsp-property-group> | Optional | Used to group a number of files so they can be given global property information. All files so described are deemed to be JSP files. | 
This is an element within the jsp-config.
The required taglib element provides information on a tag library that is used by a JSP page within the Web application.
This element associates the location of a JSP Tag Library Descriptor (TLD) with a URI pattern. Although you can specify a TLD in your JSP that is relative to the WEB-INF directory, you can also use the <taglib> tag to configure the TLD when deploying your Web application. Use a separate element for each TLD.
The following table describes the elements you can define within a taglib element.
| Element | Required/Optional | Description | 
|---|---|---|
| <taglib-location> | Optional | Gives the file name of the tag library descriptor relative to the root of the Web application. It is a good idea to store the tag library descriptor file under the  | 
| <taglib-uri> | Optional | Describes a URI, relative to the location of the  If the URI matches the URI string used in the taglib directive on the JSP page, this taglib is used. | 
This is an element within the jsp-config.
The required jsp-property-group element is used to group a number of files so they can be given global property information. All files so described are deemed to be JSP files.
The following table describes the elements you can define within a jsp-property-group element.
Table A-21 jsp-property-group Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <el-ignored> | Optional | Controls whether EL is ignored. By default, the EL evaluation is enabled for Web applications using a Servlet 2.4 or greater  | 
| <scripting-invalid> | Optional | Controls whether scripting elements are invalid in a group of JSP pages. By default, scripting is enabled. | 
| <page-encoding> | Optional | Indicates pageEncoding information. It is a translation-time error to name different encodings in the pageEncoding attribute of the page directive of a JSP page and in a JSP configuration element matching the page. It is also a translation-time error to name different encodings in the prolog or text declaration of a document in XML syntax and in a JSP configuration element matching the document. It is legal to name the same encoding through multiple mechanisms. | 
| <is-xml> | Optional | Indicates that a resource is a JSP document (XML). If true, denotes that the group of resources that match the URL pattern are JSP documents, and thus must be interpreted as XML documents. If false, the resources are assumed to not be JSP documents, unless there is another property group that indicates otherwise. | 
| <include-prelude> | Optional | A context-relative path that must correspond to an element in the Web application. When the element is present, the given path will be automatically included (as in an include directive) at the beginning of each JSP page in this jsp-property-group. | 
| <include-coda> | Optional | A context-relative path that must correspond to an element in the Web application. When the element is present, the given path will be automatically included (as in an include directive) at the end of each JSP page in this  | 
| <deferred-syntax-allowed-as-literal> | Optional | Controls whether the character sequence  | 
| <trim-directive-whitespaces> | Optional | Controls whether template text containing only white spaces must be removed from the response output. | 
| <url-pattern> | Required | Describes a pattern used to resolve URLs. The portion of the URL after the  Example patterns: /soda/grape/* /foo/* /contents *.foo The URL must follow the rules specified in the servlet 3.0 specification. | 
| default-content-type | Optional | Specifies the default  | 
| buffer | Optional | Specifies the default buffering model for  | 
| error-on-undeclared-namespace | Optional | Controls whether an error should be raised for the use of an undeclared tag in a JSP document. If set to true, when an undeclared tag is used in a JSP document, an error must be raised during the translation time. Disabled (false) by default. | 
The resource-env-ref element contains a declaration of a Web application's reference to an administered object associated with a resource in the Web application's environment. It consists of an optional description, the resource environment reference name, and an indication of the resource environment reference type expected by the Web application code.
For example:
<resource-env-ref>
    <resource-env-ref-name>jms/StockQueue</resource-env-ref-name>
    <resource-env-ref-type>javax.jms.Queue</resource-env-ref-type>
</resource-env-ref>
The following table describes the elements you can define within a resource-env-ref element.
| Element | Required/Optional | Description | 
|---|---|---|
| <description> | Optional | Provides a description of the resource environment reference. | 
| <resource-env-ref-name> | Required | Specifies the name of a resource environment reference; its value is the environment entry name used in the Web application code. The name is a JNDI name relative to the  | 
| <resource-env-ref-type> | Required | Specifies the type of a resource environment reference. It is the fully qualified name of a Java language class or interface. | 
| <lookup-name> | Optional | The JNDI name to be looked up to resolve a resource reference. | 
The optional resource-ref element defines a reference lookup name to an external resource. This allows the servlet code to look up a resource by a "virtual" name that is mapped to the actual location at deployment time.
Use a separate <resource-ref> element to define each external resource name. The external resource name is mapped to the actual location name of the resource at deployment time in the WebLogic-specific deployment descriptor weblogic.xml.
The following table describes the elements you can define within a resource-ref element.
Table A-23 resource-ref Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <description> | Optional | A text description. | 
| <res-ref-name> | Required | The name of the resource used in the JNDI tree. Servlets in the Web application use this name to look up a reference to the resource. | 
| <res-type> | Required | The Java type of the resource that corresponds to the reference name. Use the full package name of the Java type. | 
| <res-auth> | Required | Used to control the resource sign on for security. If set to  | 
| <res-sharing-scope> | Optional | Specifies whether connections obtained through the given resource manager connection factory reference can be shared. Valid values: Shareable Unshareable | 
| <lookup-name> | Optional | The JNDI name to be looked up to resolve a resource reference. | 
The security-constraint element defines the access privileges to a collection of resources defined by the <web-resource-collection> element.
For detailed instructions and an example on configuring security in Web applications, see Securing Resources Using Roles and Policies for Oracle WebLogic Server. Also, for more information on WebLogic Security, refer to Developing Applications with the WebLogic Security Service.
The following table describes the elements you can define within a security-constraint element.
Table A-24 security-constraint Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <web-resource- collection> | Required | Defines the components of the Web application to which this security constraint is applied. | 
| <auth-constraint> | Optional | Defines which groups or principals have access to the collection of Web resources defined in this security constraint. See also auth-constraint. | 
| <user-data- constraint> | Optional | Defines how the client should communicate with the server. See also user-data-constraint. | 
Each <security-constraint> element must have one or more <web-resource-collection> elements. These define the area of the Web application to which this security constraint is applied.
This is an element within the security-constraint.
The following table describes the elements you can define within a web-resource-collection element.
Table A-25 web-resource-collection Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <web-resource- name> | Required | The name of this Web resource collection. | 
| <description> | Optional | A text description of this security constraint. | 
| <url-pattern> | Optional | Use one or more of the < | 
| <http-method> | Optional | Use one or more of the < | 
This is an element within the security-constraint.
The optional auth-constraint element defines which groups or principals have access to the collection of Web resources defined in this security constraint.
The following table describes the elements you can define within an auth-constraint element.
Table A-26 auth-constraint Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <description> | Optional | A text description of this security constraint. | 
| <role-name> | Optional | Defines which security roles can access resources defined in this security-constraint. Security role names are mapped to principals using the security-role-ref | 
This is an element within the security-constraint.
The user-data-constraint element defines how the client should communicate with the server.
The following table describes the elements you may define within a user-data-constraint element.
Table A-27 user-data-constraint Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <description> | Optional | A text description. | 
| <transport- guarantee> | Required | Specifies that the communication between client and server. WebLogic Server establishes a Secure Sockets Layer (SSL) connection when the user is authenticated using the  Range of values: 
 
 
 | 
Use the optional login-config element to configure how the user is authenticated; the realm name that should be used for this application; and the attributes that are needed by the form login mechanism.
If this element is present, the user must be authenticated in order to access any resource that is constrained by a <security-constraint> defined in the Web application. Once authenticated, the user can be authorized to access other resources with access privileges.
The following table describes the elements you can define within a login-config element.
| Element | Required/Optional | Description | 
|---|---|---|
| <auth-method> | Optional | Specifies the method used to authenticate the user. Possible values: 
 
 
 You can define multiple authentication methods as a comma separated list to provide a fall-back mechanism. Authentication will be attempted in the order the values are defined in the auth-method list. See "Providing a Fallback Mechanism for Authentication Methods" in Developing Applications with the WebLogic Security Service. | 
| <realm-name> | Optional | The name of the realm that is referenced to authenticate the user credentials. If omitted, the realm defined with the Auth Realm Name field on the Web application > Configuration > Other tab of the WebLogic Server Administration Console is used by default. The  | 
| <form-login- config> | Optional | Use this element if you configure the  | 
This is an element within the login-config.
Use the <form-login-config> element if you configure the <auth-method> to FORM.
Table A-29 form-login-config Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <form-login-page> | Required | The URI of a Web resource relative to the document root, used to authenticate the user. This can be an HTML page, JSP, or HTTP servlet, and must return an HTML page containing a  | 
| <form-error-page> | Required | The URI of a Web resource relative to the document root, sent to the user in response to a failed authentication login. | 
The following table describes the elements you can define within a security-role element.
Table A-30 security-role Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <description> | Optional | A text description of this security role. | 
| <role-name> | Required | The role name. The name you use here must have a corresponding entry in the WebLogic-specific deployment descriptor,  | 
The optional env-entry element declares an environment entry for an application. Use a separate element for each environment entry.
The following table describes the elements you can define within an env-entry element.
| Element | Required/Optional | Description | 
|---|---|---|
| <description> | Optional | A textual description. | 
| <env-entry-name> | Required | The name of the environment entry. | 
| <env-entry-value> | Required | The value of the environment entry. | 
| <env-entry-type> | Required | The type of the environment entry. Can be set to one of the following Java types: java.lang.Boolean java.lang.String java.lang.Integer java.lang.Double java.lang.Float | 
| <lookup-name> | Optional | The JNDI name to be looked up to resolve a resource reference. | 
The optional ejb-ref element defines a reference to an EJB resource. This reference is mapped to the actual location of the EJB at deployment time by defining the mapping in the WebLogic-specific deployment descriptor file, weblogic.xml. Use a separate <ejb-ref> element to define each reference EJB name.
The following table describes the elements you can define within an ejb-ref element.
| Element | Required/Optional | Description | 
|---|---|---|
| <description> | Optional | A text description of the reference. | 
| <ejb-ref-name> | Required | The name of the EJB used in the Web application. This name is mapped to the JNDI tree in the WebLogic-specific deployment descriptor  | 
| <ejb-ref-type> | Required | The expected Java class type of the referenced EJB. | 
| <home> | Required | The fully qualified class name of the EJB home interface. | 
| <remote> | Required | The fully qualified class name of the EJB remote interface. | 
| <ejb-link> | Optional | The  | 
| <run-as> | Optional | A security role whose security context is applied to the referenced EJB. Must be a security role defined with the  | 
| <lookup-name> | Optional | The JNDI name to be looked up to resolve a resource reference. | 
The ejb-local-ref element is used for the declaration of a reference to an enterprise bean's local home. The declaration consists of:
An optional description
The EJB reference name used in the code of the Web application that references the enterprise bean. The expected type of the referenced enterprise bean
The expected local home and local interfaces of the referenced enterprise bean
Optional ejb-link information, used to specify the referenced enterprise bean
The following table describes the elements you can define within an ejb-local-ref element.
Table A-33 ejb-local-ref Elements
| Element | Required/Optional | Description | 
|---|---|---|
| <description> | Optional | A text description of the reference. | 
| <ejb-ref-name> | Required | Contains the name of an EJB reference. The EJB reference is an entry in the Web application's environment and is relative to the  For example: <ejb-ref-name>ejb/Payroll</ejb-ref-name> | 
| <ejb-ref-type> | Required | The  <ejb-ref-type>Entity</ejb-ref-type> <ejb-ref-type>Session</ejb-ref-type> | 
| <local-home> | Required | Contains the fully-qualified name of the enterprise bean's local home interface. | 
| <local> | Required | Contains the fully-qualified name of the enterprise bean's local interface. | 
| <ejb-link> | Optional | The  The name in the  The path name is relative to the WAR file containing the Web application that is referencing the EJB. This allows multiple EJBs with the same  Used in:  Examples: <ejb-link>EmployeeRecord</ejb-link> <ejb-link>../products/product.jar#ProductEJB</ejb-link> | 
| <lookup-name> | Optional | The JNDI name to be looked up to resolve a resource reference. | 
The XML schema for the servlet 3.0 deployment descriptor. WebLogic Server fully supports HTTP servlets as defined at http://jcp.org/en/jsr/detail?id=315. However, the version attributed must be set to 3.0 in order to enforce 3.0 behavior.
The following table describes the elements you can define within an web-app element.
The optional message-destination-ref element specifies a reference to a message destination associated with a resource. The logical destination described by this element is mapped to a physical destination in the deployment descriptor.
The following table describes the elements you can define within an message-destination-ref element.
Table A-35 message-destination-ref Elements
| Element | Required/Optional | Description | 
|---|---|---|
| description | Optional | Provides a description of the message destination reference. | 
| message-destination-name | Required | Specifies a name for a message destination. This name must be unique among the names of message destinations within the deployment descriptor. | 
| mapped-name | Optional | Maps this message destination to a "logical" name. | 
| lookup-name | Optional | The JNDI name to be looked up to resolve the message destination. | 
| message-destination-type | Required | Specifies the type of the destination. The type is specified by the Java interface expected to be implemented by the destination. Must be supplied unless an injection target is specified, in which case the type of the target is used. If both are specified, the type must be assignment compatible with the type of the injection target. | 
| message-destination-usage | Optional | Specifies the use of the message destination indicated by the reference. The value indicates whether messages are consumed from the message destination, produced for the destination, or both. Valid values are one of the following: 
 If not specified,  | 
| message-destination-link | Optional | Links a message destination reference or message-driven bean to a message destination. |