A Oracle ADF XML Files
This appendix includes the following sections:
About ADF Metadata Files
An Oracle Fusion web application uses various metadata XML files that summarizes basic information about data, which can make finding and working with particular instances of data easier. These files are used to configure the runtime behavior of the system.
Metadata files in a Fusion web application are structured XML files used by the application to:
-
Specify the parameters, methods, and return values available to your application's Oracle ADF data control usages
-
Create objects in the Oracle ADF binding context and define the runtime behavior of those objects
-
Define configuration information about the UI components in JSF and ADF Faces
-
Define application configuration information for the Java EE application server
In the case of ADF bindings, you can use the binding-specific editors to customize the runtime properties of the binding objects. You can open a binding editor when you display the Structure window for a page definition file and choose Go to Properties from the context menu.
Additionally, you can view and edit the contents of any metadata file in JDeveloper's XML editor. The easiest way to work with these files is through the Structure window and Properties window. In the Structure window, you can choose an element and in the Properties window, you can define attribute values for the element, often by choosing among dropdown menu choices. Use this appendix to learn the choices you can choose in the case of the Oracle ADF-specific elements.
ADF File Overview Diagram
The Oracle ADF File Hierarchy diagram helps you to understand the interrelationship of the metadata files used to work with the ADF Business Components data control in a view layer project.
The relationship between the Oracle ADF metadata files defines dependencies between the model data and the user interface projects. The dependencies are defined as file references within XML elements of the files, where these design time definitions in the Model project reference the DataBindings.jpx file in the ViewController project, which in turn references the page definition files.
Figure A-1 illustrates the hierarchical relationship of the XML metadata files that you might work with in a Fusion web application that uses an ADF Business Components application module as a service interface to JSF web pages.
Figure A-1 Oracle ADF File Hierarchy Overview for the Fusion Web Application

Description of "Figure A-1 Oracle ADF File Hierarchy Overview for the Fusion Web Application"
Oracle ADF Data Control Files
In a Fusion web application containing ADF Business Components, the data control implementation files are contained within the application. The application module and view object XML component descriptor files provide the references for the data control. These files, with the bc4j.xcfg
file, provide the necessary information for the data control.
An application that uses ADF Business Components in one project and a non-ADF Business Components data control in another project may have a DataControls.dcx
file, as well as supporting <sessionbeanname>
.xml
and <beanname>
.xml
files.
Oracle ADF Data Binding Files
These standard XML configuration files for a Fusion web application appear in your user interface project:
-
adfm.xml
: This file lists theDataBindings.cpx
file that is available in the current project.See adfm.xml for more information.
-
DataBindings.cpx
: This file contains the page map, page definitions references, and data control references. The file is created the first time you create a data binding for a UI component (either from the Structure window or from the Data Controls panel). TheDataBindings.cpx
file defines the Oracle ADF binding context for the entire application. The binding context provides access to the bindings and data controls across the entire application. TheDataBindings.cpx
file also contains references to the<pagename>
PageDef.xml
files that define the metadata for the Oracle ADF bindings in each web page.For more information, see DataBindings.cpx.
-
<pagename>
PageDef.xml
: This is the page definition XML file. It associates web page UI components with data, or data controls. JDeveloper creates this file each time you design a new web page using the Data Controls panel or Structure window. These XML files contain the metadata used to create the bindings that populate the data in the web page's UI components. For every web page that refers to an ADF binding, there must be a corresponding page definition file with binding definitions.For more information, see pageNamePageDef.xml.
Web Configuration Files
These standard XML configuration files required for a JSF application appear in your user interface project:
-
web.xml
: Part of the application's configuration is determined by the contents of its Java EE application deployment descriptor,web.xml
. Theweb.xml
file defines everything about your application that a server needs to know. The file plays a role in configuring the Oracle ADF data binding by setting up theADFBindingFilter
. Additional runtime settings include servlet runtime and initialization parameters, custom tag library location, and security settings.For more information about ADF data binding and JSF configuration options, see web.xml.
An ADF Faces application typically uses its own set of configuration files in addition to
web.xml
. For more information, see Configuration in trinidad-config.xml in Developing Web User Interfaces with Oracle ADF Faces. -
adfc-config.xml:
The configuration file for an ADF unbounded task flow. The configuration file contains metadata about the activities and control flows contained in the unbounded task flow. The default name for this file isadfc-config.xml
, but an end user can change the name.For more information, see adfc-config.xml.
-
task-flow-definition.xml
: The configuration file for an ADF bounded task flow. The configuration file contains metadata about the activities and control flows contained in the bounded task flow. The default name for this file can be task-flow-defintion.xml
or whatever an end user specifies in the Create ADF Task Flow dialog. The same application can contain multiple task flow definition files.For more information, see task-flow-definition.xml.
ADF File Syntax Diagram
Oracle ADF File Syntax Diagram helps you to understand the hierarchical interrelationship of the XML metadata files in a web application that uses an ADF application module as a service interface to ADF Business Components.
Figure A-2 illustrates the hierarchical relationship of the XML metadata files that you might work with in a web application that uses an ADF application module as a service interface to ADF Business Components. At runtime, the objects created from these files interact in this sequence:
-
When the first request for an ADF databound web page occurs, the servlet registers the Oracle ADF servlet filter
ADFBindingFilter
named in theweb.xml
file. -
The binding filter creates an empty binding context.
-
When a page is rendered, the binding filter asks the binding context to load a corresponding
PageDef.xml
for the page. -
The binding context creates the binding container by loading the
<page>
file as referenced by the<pagemap>
element in theDataBindings.cpx
file. -
The
adfm.xml
file loads theDataBindings.cpx
contents and finds the rightPageDef.xml
based on the<pagemap>
element reference to the<pageDefinitionUsage>
element. -
The binding container's
prepareModel
phase prepares and refreshes all relevant executables (most are markeddeferred
by default). -
An iterator binding gets executed by referencing the named method on the data control found through the data control factory named in the case of ADF Business Components in the
bc4j.xcfg
file. -
The binding container also creates the bindings defined in the
<bindings>
section of thepagename
PageDef.xml
file for the mapped web page. -
The web page references to ADF bindings through EL using the expression
#{bindings}
are resolved by accessing the binding container of the page. -
The page pulls the available data from the bindings in the binding container.
Figure A-2 Oracle ADF File Hierarchy and Syntax Diagram for an ADF BC-based Web Application

adfm.xml
The adfm.xml file is a registry of registries used by the ADF framework to quickly find all metadata files used at runtime. This registry XML file records four types of metadata files —.cpx, .dcx, .xcfg, .jpx.
The adfm.xml
file contains the classpath-relative paths for the .cpx
, .dcx
, .jpx
, and .xcfg
files in each design time project that is included in the runtime deployed application. The adfm.xml
file operates as a dynamically maintained "Registry of Registries" that is used to quickly find all .cpx
, .dcx
, .jpx
, and .xcfg
files (which are themselves registries of metadata).
The file registry is used extensively by the ADF Library resource catalog browsing implementations, by ADF Model layer design time, and at runtime during merge and discovery.
When a developer creates a binding on a page, JDeveloper adds metadata files (for example, page definitions) in the project source tree. The adfm.xml
file then notes the location of each.
When a project is built, the adfm.xml
file is put in project-root
/adfmsrc/META-INF/adfm.xml
. The project-level archive deployment profiles locate the file at META-INF/adfm.xml
.
At runtime, the application classpath is scanned to build the list of .cpx
files that comprise the application. The application then loads each.cpx
as needed to create the binding context. For details about ADF Model layer usage, see What Happens When You Use the Data Controls Panel.
Four types of sub registries are recorded by the adfm.xml
file:
-
DataBindingRegistry
(.cpx
) -
DataControlRegistry
(.dcx
) -
BusinessComponentServiceRegistry
(.xcfg
) -
BusinessComponentProjectRegistry
(.jpx
)
modelProjectName.jpx
JDeveloper uses the modelProjectName.jpx file as a registry to track the contents of the model packages. It also contains metadata for shared ADF application modules present in the project, which is used by both design-time and runtime components.
The.jpx
file contains configuration information that JDeveloper uses in the design time to allow you to create the data model project with ADF Business Components. It also contains metadata that defines how a shared application module is used at runtime. Because the shared application module can be accessed by any data model project in the same Fusion web application, JDeveloper maintains the scope of the shared application module in the ADF Business Components project configuration file.
This file is saved in the src
directory of the project. For example, the Summit sample application for Oracle ADF stores the Model.jpx
file in the .src/oracle/summit/model
subdirectory of the Model
project.
The following example displays a sample default.jpx
file.
<JboProject xmlns="http://xmlns.oracle.com/bc4j" Name="Model" Version="12.1.2.66.11" SeparateXMLFiles="true" PackageName="oracle.summit.model"> <DesignTime> <Attr Name="_appModuleNames2" Value="oracle.summit.model.services.BackOfficeAppModule"/> <Attr Name="_jprName" Value="../../../../Model.jpr"/> <Attr Name="_appModuleNames1" Value="oracle.summit.model.services.CustomerSelfServiceAppModule"/> <Attr Name="_appModuleNames0" Value="oracle.summit.model.services.SummitAppModule"/> <Attr Name="_jbo.TypeMapEntries" Value="Java"/> <Attr Name="_NamedConnection" Value="summit_adf"/> </DesignTime> <Containee Name="assoc" PackageName="oracle.summit.model.entities.assoc" ObjectType="JboPackage"> <DesignTime> <Attr Name="_AS" Value="true"/> </DesignTime> </Containee> <Containee Name="entities" PackageName="oracle.summit.model.entities" ObjectType="JboPackage"> <DesignTime> <Attr Name="_EO" Value="true"/> <Attr Name="_VO" Value="true"/> </DesignTime> </Containee> <Containee Name="services" PackageName="oracle.summit.model.services" ObjectType="JboPackage"> <DesignTime> <Attr Name="_AM" Value="true"/> </DesignTime> </Containee> <Containee Name="links" PackageName="oracle.summit.model.views.links" ObjectType="JboPackage"> <DesignTime> <Attr Name="_VL" Value="true"/> </DesignTime> </Containee> <Containee Name="readonly" PackageName="oracle.summit.model.views.readonly" ObjectType="JboPackage"> <DesignTime> <Attr Name="_VO" Value="true"/> </DesignTime> </Containee> <Containee Name="views" PackageName="oracle.summit.model.views" ObjectType="JboPackage"> <DesignTime> <Attr Name="_VO" Value="true"/> </DesignTime> </Containee> </JboProject>
bc4j.xcfg
The bc4j.xcfg file contains metadata information about the ADF application module and runtime parameters that have been configured to manage the runtime behavior of each application module instance.
The bc4j.xcfg
file contains metadata information about application module names, the database connection used by the application module, and the runtime parameters the user has configured for the application module.
The bc4j.xcfg
file is located in the ./common
subdirectory relative to the application module's XML component definition. All of the configurations for all of the application modules in a single Java package are saved in that same file. For example, if you look at the bc4j.xcfg
file in the /Model/src/oracle/summit/model/services/common
directory of the Summit ADF sample application's Model
project, you see the configurations for its application modules. For details about editing the configurations, see How to Change Your Application Module's Runtime Configuration and Setting Pool Configuration Parameters.
Example A-1 displays a sample bc4j.xcfg
file from the Summit ADF sample application.
Example A-1 Sample bc4j.xcfg File
<?xml version = '1.0' encoding = 'UTF-8'?> <BC4JConfig version="11.1" xmlns="http://xmlns.oracle.com/bc4j/configuration"> <AppModuleConfigBag ApplicationName="oracle.summit.model.services.SummitAppModule"> <AppModuleConfig name="SummitAppModuleLocal" DeployPlatform="LOCAL" JDBCName="summit_adf" jbo.project="oracle.summit.model.Model" java.naming.factory.initial="oracle.jbo.common. JboInitialContextFactory" ApplicationName="oracle.summit.model.services.SummitAppModule"> <Database jbo.TypeMapEntries="Java"/> <Security AppModuleJndiName="oracle.summit.model.services.SummitAppModule"/> </AppModuleConfig> <AppModuleConfig name="SummitAppModuleShared" DeployPlatform="LOCAL" JDBCName="summit_adf" jbo.project="oracle.summit.model.Model" java.naming.factory.initial="oracle.jbo.common.JboInitialContextFactory" ApplicationName="oracle.summit.model.services.SummitAppModule"> <AM-Pooling jbo.ampool.isuseexclusive="false" jbo.ampool.maxpoolsize="1"/> <Database jbo.TypeMapEntries="Java"/> <Security AppModuleJndiName="oracle.summit.model.services.SummitAppModule"/> </AppModuleConfig> </AppModuleConfigBag> <AppModuleConfigBag ApplicationName="oracle.summit.model.services.CustomerSelfServiceAppModule"> <AppModuleConfig name="CustomerSelfServiceLocal" jbo.project="oracle.summit.model.Model" ApplicationName="oracle.summit.model.services.CustomerSelfServiceAppModule" DeployPlatform="LOCAL" JDBCName="summit_adf"> <Database jbo.TypeMapEntries="Java"/> <Security AppModuleJndiName="oracle.summit.model.services.CustomerSelfServiceAppModule"/> </AppModuleConfig> <AppModuleConfig name="CustomerSelfServiceShared" jbo.project="oracle.summit.model.Model" ApplicationName="oracle.summit.model.services.CustomerSelfServiceAppModule" DeployPlatform="LOCAL" JDBCName="summit_adf"> <AM-Pooling jbo.ampool.maxpoolsize="1" jbo.ampool.isuseexclusive="false"/> <Database jbo.TypeMapEntries="Java"/> <Security AppModuleJndiName="oracle.summit.model.services.CustomerSelfServiceAppModule"/> </AppModuleConfig> </AppModuleConfigBag> <AppModuleConfigBag ApplicationName="oracle.summit.model.services.BackOfficeAppModule"> <AppModuleConfig name="BackOfficeAppModuleLocal" jbo.project="oracle.summit.model.Model" ApplicationName="oracle.summit.model.services.BackOfficeAppModule" DeployPlatform="LOCAL" JDBCName="summit_adf"> <Database jbo.TypeMapEntries="Java"/> <Security AppModuleJndiName="oracle.summit.model.services.BackOfficeAppModule"/> </AppModuleConfig> <AppModuleConfig name="BackOfficeAppModuleShared" jbo.project="oracle.summit.model.Model" ApplicationName="oracle.summit.model.services.BackOfficeAppModule" DeployPlatform="LOCAL" JDBCName="summit_adf"> <AM-Pooling jbo.ampool.maxpoolsize="1" jbo.ampool.isuseexclusive="false"/> <Database jbo.TypeMapEntries="Java"/> <Security AppModuleJndiName="oracle.summit.model.services.BackOfficeAppModule"/> </AppModuleConfig> </AppModuleConfigBag> </BC4JConfig>
DataBindings.cpx
In an ADF web application, as soon as you drop a databound component on your page, a DataBindings.cpx file gets created. The DataBindings.cpx keeps track of the individual page definition files used within the project, as well as the DataControls mapping to things such as ADF Business Components Application Modules.
The DataBindings.cpx
file is created in the user interface project the first time you drop a data control usage onto a web page in the visual editor. The DataBindings.cpx
file defines the Oracle ADF binding context for the entire application and provides the metadata from which the Oracle ADF binding objects are created at runtime. It is used extensively by the ADF Library resource catalog browsing implementations, and also by the .cpx
and .dcx
design time and runtime merge and discovery. When you insert a databound UI component into your document, the page will contain binding expressions that access the Oracle ADF binding objects at runtime.
The DataBindings.cpx
file appears in the /src
directory of the user interface project. When you double-click the file node, the binding context description appears in the XML source editor. (To edit the binding context parameters, use the Properties window and choose the desired parameter in the Structure window.)
DataBindings.cpx Syntax
The top level element of the DataBindings.cpx
file is <Application>
. For example:
<?xml version="1.0" encoding="UTF-8" ?> <Application xmlns="http://xmlns.oracle.com/adfm/application" version="11.1.1.56.60" id="DataBindings" SeparateXMLFiles="false" Package="oracle.summit.view" ClientType="Generic">
Figure A-3 shows the structure definition of the DataBindings.cpx
file in the Summit standalone sample applications for Oracle ADF.
Figure A-3 Structure of the DataBindings.cpx File

Description of "Figure A-3 Structure of the DataBindings.cpx File"
The child elements have the following usages:
-
<definitionFactories>
registers a factory class to create the ADF binding objects associated with a particular namespace at runtime. The factory class is specific to the namespace associated with the type of ADF binding (for instance, a task flow binding). -
<pageMap>
maps all user interface URLs and the corresponding page definition usage name. This map is used at runtime to map a URL to its page definition. -
<pageDefinitionUsages>
maps a page definition usage (BindingContainer
instance) name to the corresponding page definition. Theid
attribute represents the usage ID. The path attribute represents the full path to the page definition. -
<dataControlUsages>
declares a list of data control usages (shortnames) and corresponding path to the data control definition entries in the.dcx
or.xcfg
file.
Table A-1 describes the attributes of the DataBindings.cpx
elements.
Table A-1 Attributes of the DataBindings.cpx File Elements
Element Syntax | Attributes | Attribute Description |
---|---|---|
|
|
A URI. Identifies the location of the executable elements in the page definition usage. |
|
The fully qualified class name. Identifies the location of the factory class that creates the page definition usage objects. |
|
|
|
The full directory path. Identifies the location of the user interface page. |
|
A unique qualifier. Names the page definition ID that appears in the ADF page definition file. The ADF binding servlet looks at the incoming URL requests and checks that the |
|
|
|
A unique qualifier. References the page definition ID that appears in the ADF page definition file. |
|
The fully qualified package name. Identifies the location of the user interface page's ADF page definition file. |
|
|
|
A unique qualifier. Identifies the data control usage as is defined in the |
|
The fully qualified package name. Identifies the location of the data control. |
DataBindings.cpx Sample
Example A-2 shows the syntax for the DataBindings.cpx
file in the Summit ADF sample application.
The ADF executable definition factory (factory
element) is named by a className
attribute and is associated with a namespace
. At runtime, the factory class creates the executable definition objects that leads to the creation of the binding objects for the ADF binding container associated with a particular page definition. The factory locates the page definition through two DataBindings.cpx
file elements: the pageMap
element that maps the page URL to the page definition ID (usageId
attribute) assigned at design time and the pageDefinitionUsages
element that maps the ID to the location of the page definition from the project or project classpath.
Additionally, the ADF Business Components data control (BC4JDataControl
element) is named by the id
attribute. The combination of the Package
attribute and the Configuration
attribute is used to locate the bc4j.xcfg
file in the ./common
subdirectory of the indicated package. The configuration contains the information of the application module name and all the runtime parameters the user has configured.
Example A-2 Sample DataBindings.cpx File
<?xml version="1.0" encoding="UTF-8" ?> <Application xmlns="http://xmlns.oracle.com/adfm/application" version="11.1.1.56.60" id="DataBindings" SeparateXMLFiles="false" Package="oracle.summit.view" ClientType="Generic"> <definitionFactories> <factory nameSpace="http://xmlns.oracle.com/adf/controller/binding" className="oracle.adf.controller.internal.binding.TaskFlowBindingDefFactoryImpl"/> <dtfactory className="oracle.adf.controller.internal.dtrt.binding.BindingDTObjectFactory"/> <factory nameSpace="http://xmlns.oracle.com/adfm/dvt" className="oracle.adfinternal.view.faces.dvt.model.binding.FacesBindingFactory"/> </definitionFactories> <pageMap> <page path="/index.jsf" usageId="oracle_summit_view_indexPageDef"/> <page path="/Customers.jsff" usageId="oracle_summit_view_CustomersPageDef"/> <page path="/orders/Orders.jsff" usageId="oracle_summit_view_OrdersPageDef"/> <page path="/carousel/InventoryControl.jsff" usageId="oracle_summit_view_InventoryControlTestPageDef"/> </pageMap> <pageDefinitionUsages> <page id="oracle_summit_view_CustomersPageDef" path="oracle.summit.view.pageDefs.CustomersPageDef"/> <page id="oracle_summit_view_indexPageDef" path="oracle.summit.view.pageDefs.indexPageDef"/> <page id="oracle_summit_view_OrdersPageDef" path="oracle.summit.view.pageDefs.OrdersPageDef"/> <page id="oracle_summit_view_InventoryControlTestPageDef" path="oracle.summit.view.pageDefs.InventoryControlPageDef"/> </pageDefinitionUsages> <dataControlUsages> <BC4JDataControl id="BackOfficeAppModuleDataControl" Package="oracle.summit.model.services" FactoryClass="oracle.adf.model.bc4j.DataControlFactoryImpl" SupportsTransactions="true" SupportsFindMode="true" SupportsRangesize="true" SupportsResetState="true" SupportsSortCollection="true" Configuration="BackOfficeAppModuleLocal" syncMode="Immediate" xmlns="http://xmlns.oracle.com/adfm/datacontrol"/> </dataControlUsages> </Application>
pageNamePageDef.xml
In an ADF web application, as soon as you draga component from Data Control panel to a JSF page, a page definition file gets created with the name pageNamePageDef.xml. The pageNamePageDef.xml file contains binding metadata for each data bound UI element present on the page.
The pageName
PageDef.xml
files are created each time you insert a databound component into a web page using the Data Controls panel or Structure window. These XML files define the Oracle ADF binding container for each web page in the application. The binding container provides access to the bindings within the page. You will have one XML file for each databound web page.
Caution:
The DataBindings.cpx
file maps JSF pages to their corresponding page definition files. If you change the name of a page definition file or a JSF page, JDeveloper does not automatically refactor the DataBindings.cpx
file. You must manually update the page mapping in the DataBindings.cpx
file.
The PageDef.xml
file appears in the /src/view
directory of the user interface project. The Applications window displays the file in the view package of the Application Sources node. When you double-click the file node, the page description appears in the XML source editor. To edit the page description parameters, use the Properties window and choose the desired parameter in the Structure window. See Working with Page Definition Files.
There are important differences in how the page definitions are generated for methods that return a single value and a collection.
PageDef.xml Syntax
The top-level element of the PageDef.xml
file is <pageDefinition>
:
<pageDefinition xmlns="http://xmlns.oracle.com/adfm/uimodel" version="11.1.1.59.23" id="<pagename>PageDef" Package="oracle.summit.view.pageDefs">
where the XML namespace attribute (xmlns
) specifies the URI to which the ADF binding container binds at runtime. Only the package name is editable; all other attributes should have the values shown.
The following example displays the child element hierarchy of the <pageDefinition>
element. Note that each business service for which you have created a data control will have its own <AdapterDataControl>
definition.
<?xml version="1.0" encoding="UTF-8" ?> <pageDefinition> <parameters> ... </parameters> <executables> ... </executables> <bindings> ... </bindings> </pageDefinition>
The child elements have the following usages:
-
<parameters>
defines page-level parameters that are EL accessible. These parameters store information local to the web page request and may be accessed in the binding expressions. -
<executables>
defines the list of items (methods, view objects, and accessors) to execute during theprepareModel
phase of the ADF page lifecycle. Methods to be executed are defined by<methodIterator>
. The lifecycle performs the execute in the sequence listed in the<executables>
section. Whether or not the method or operation is executed depends on itsRefresh
orRefreshCondition
attribute value. Built-in operations on the data control are defined by:-
<page>
: definition for a nested page definition (binding container) -
<iterator>
: definition to a named collection inDataControls
-
<accessorIterator>
: definition to get an accessor in a data control hierarchy -
<methodIterator>
: definition to get to an iterator returned by an invoked method defined by amethodAction
in the same file -
<variableIterator>
: internal iterator that contains variables declared for the binding container -
<invokeAction>
: definition of which method to invoke as an executableNote:
Only use
invokeAction
when your application does not use the ADF Controller module from the Fusion web application technology stack. If your application uses the ADF Controller module, Oracle recommends that you use a task flow method call activity, as described in Using Method Call Activities.
-
-
<bindings>
refers to an entry in<executables>
to get to the collection from which bindings extract/submit attribute level data.
Table A-2 describes the attributes of the top-level <pageDefinition>
element.
Table A-2 Attributes of the PageDef.xml File <pageDefinition> Element
Element Syntax | Attributes | Attribute Description |
---|---|---|
|
|
Fully qualified class name to create when controller requests a |
|
Enables currency validation for this bindingContainer when a postback occurs. This is to confirm that the web tier state matches the state that particular page was rendered with. |
|
|
FindMode is for legacy (10.1.2) use only and indicates whether this bindingContainer should start out in findMode when initially prepared. |
|
|
Fully qualified package name. Identifies the class which contains translation strings for any bindings. |
|
|
Determines if data validation occurs. The supported values are:
Setting a value for this attribute can be useful if you want to skip data validation on, for example, a train component. For more information, see How to Create the Train Model in Developing Web User Interfaces with Oracle ADF Faces. |
|
|
An EL expression that should resolve at runtime to whether this binding and the associated component should be rendered or not. |
Table A-3 describes the attributes of the child element of <parameters>
.
Table A-3 Attributes of the PageDef.xml File <parameters> Element
Element Syntax | Attributes | Attribute Description |
---|---|---|
|
|
Specifies when the parameter should be evaluated: |
|
Unique identifier. May be referenced by ADF bindings. |
|
|
Indicates the usage of the variable within the binding container:
|
|
|
Indicates whether the parameter value may be modified or not. Set to |
|
|
A default value, which can be an EL expression. |
Table A-4 describes the attributes of the PageDef.xml
<executables>
elements.
Table A-4 Attributes of the PageDef.xml File <executables> Element
Element Syntax | Attributes | Attribute Description |
---|---|---|
|
|
Specifies any other accessor defined by this binding. |
|
Specifies the view or action to which the iterator is bound. |
|
|
Identifies the Java type of beans in the associated iterator or collection. |
|
|
If |
|
|
Specifies the rate of events when a component is wired to data via this iterator and is in polling event mode. |
|
|
Interprets and returns the collection referred to by this iterator binding. |
|
|
Unique identifier. May be referenced by any ADF value binding. |
|
|
Reference to the |
|
|
Used for ADF Business Components only. A boolean value determines whether the collection is an object type or not. |
|
|
Specifies the number of data objects in a range to fetch from the bound collection. The range defines a window you can use to access a subset of the data objects in the collection. Typically, when you create a component by dragging an object from the Data Controls panel, the range size is set to 25. Use |
|
|
Determines when to invoke the executable. Oracle recommends that you do not change from the default value (
|
|
|
An EL expression that determines if the executable should be refreshed. Use with the executable's |
|
|
Use to handle dependencies between executables. For example, you can set a condition so that this executable refreshes after another executable. |
|
|
Specify a value to determine if a result set returns the number of rows you specify as a value. If you set Set |
|
|
Specifies whether the iterator is sortable or not. |
|
|
Only use |
|
|
Determines the action to invoke. This may be on any
|
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
See |
|
|
See |
|
|
|
Identifies the Java type of beans in the associated iterator or collection. |
|
This is for backward compatibility to indicate which class implements the runtime for this binding definition. Not used in current JDeveloper release. |
|
|
See |
|
|
See |
|
|
Specifies the rate of events when a component is wired to data via this iterator and is in polling event mode. |
|
|
Name of the |
|
|
Used internally by ADF. |
|
|
Unique identifier. May be referenced by any ADF value binding. |
|
|
Not used by EJB session facade data control (used by ADF Business Components only). |
|
|
See |
|
|
See |
|
|
Specifies the condition after which the page should be refreshed. |
|
|
See |
|
|
See |
|
< |
|
Unique identifier. In the case of |
|
Specifies the rate of events when a component is wired to data via this iterator and is in polling event mode. |
|
|
Used by |
|
|
See |
|
|
Specifies the condition after which the page should be refreshed. |
|
|
See |
Table A-5 describes the attributes of the PageDef.xml <bindings>
element.
Table A-5 Attributes of the PageDef.xml File <bindings> Element
Element Syntax | Attributes | Attribute Description |
---|---|---|
|
|
Fully qualified package name. Identifies the class for which the data control is created. In the case of the EJB session facade, this is the session bean. |
|
This is for backward compatibility to indicate which class implements the runtime for this binding definition. This is used by earlier versions of JDeveloper. |
|
|
Name of the |
|
|
Used by default when you drop an operation from the Data Controls panel in the automatically configured |
|
|
Specifies the instance name for the action. |
|
|
Specifies the |
|
|
Use if you want to use the result of a method action binding (once converted to a |
|
|
|
Set to |
|
This is for backward compatibility to indicate which class implements the runtime for this binding definition. This is used by earlier versions of JDeveloper. |
|
|
Specifies the event strategy for the component when run with ADS (Active Data Services). Can be specified as push poll ppr none |
|
|
Used internally by ADF. |
|
|
This is the class name for a o |
|
|
Used internally by ADF. |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
Refers to the |
|
|
Refers to the entry in the message bundle for this |
|
|
|
Set to |
|
This is for backward compatibility to indicate which class implements the runtime for this binding definition. This is used by earlier versions of JDeveloper. |
|
|
Identifies whether the value at the zero index in the static value list in this boolean list binding represents |
|
|
Used internally by ADF. |
|
|
This is the class name for a |
|
|
Used internally by ADF. |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
Refers to the |
|
|
Refers to the |
|
|
Determines whether this list binding is for navigation, contains a static list of values or is an LOV type list. |
|
|
Describes whether this list binding has a null value and, if so, whether it should be displayed at the beginning or the end of the list. |
|
|
Refers to the entry in the message bundle for this |
|
< |
|
Identifies the update policy for the component. Valid values are |
|
Used internally by ADF. |
|
|
This is the class name for a |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
Refers to the |
|
|
Refers to the entry in the message bundle for this |
|
|
Wraps the data binding XML for the ADF Faces Gantt chart component. |
|
< |
|
Identifies the gauge type. |
|
Identifies the LED style for the gauge. |
|
|
Identifies the update policy for the component. Valid values are |
|
|
Used internally by ADF. |
|
|
This is the class name for a |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
Refers to the |
|
|
Refers to the entry in the message bundle for this |
|
|
Wraps the data binding XML for the ADF Faces |
|
< |
|
Identifies the graph type. |
|
Identifies the update policy for the component. Valid values are |
|
|
Used internally by ADF. |
|
|
This is the class name for a |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
Refers to the |
|
|
Refers to the entry in the message bundle for this |
|
|
Wraps the data binding XML for the ADF Faces |
|
|
|
Set to |
|
This is for backward compatibility to indicate which class implements the runtime for this binding definition. This is used by earlier versions of JDeveloper. |
|
|
Used internally by ADF. |
|
|
This is the class name for a |
|
|
Used internally by ADF. |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
Refers to the |
|
|
Refers to the |
|
|
Determines whether this list binding is for navigation, contains a static list of values, or is an LOV type list. |
|
|
The value of this attribute determines if the list binding passes the actual value ( |
|
|
Specifies the number of items to display in a choice list when you want to provide a shortcut for the end user to display their most recent selections. For example, a form might display a choice list of supplier ID values to drive a purchase order form. In this case, you can allow users to choose from a list of their most recently view suppliers, where the number of supplier choices is determined by the count you enter. The default for the choice list is to display all values for the attribute and is specified by the count 0 (zero). |
|
|
Specifies the |
|
|
Describes whether this list binding has a null value and, if so, whether it should be displayed at the beginning of the list or the end. |
|
|
Refers to the entry in the message bundle for this |
|
|
Defines a static list of values that will be rendered in the bound list component. |
|
< |
|
Identifies the update policy for the component. Valid values are |
|
Used internally by ADF. |
|
|
This is the class name for a |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
Refers to the |
|
|
Refers to the entry in the message bundle for this |
|
|
Wraps the data binding XML for the ADF Data Visualization geographic map component. |
|
|
|
Fully qualified package name. Identifies the class for which the data control is created. In the case of the EJB session facade, this is the session bean. |
|
This is for backward compatibility to indicate which class implements the runtime for this binding definition. This is used by earlier versions of JDeveloper. |
|
|
This is the class to which the method being invoked belongs. |
|
|
Name of the |
|
|
Used internally by ADF. |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
A dot-separated EL path to a Java object instance on which the associated method is to be invoked. |
|
|
Set to |
|
|
Set to |
|
|
Indicates the name of the operation on the given instance or class that needs to be invoked for this |
|
|
Whether this action requires that the model be updated before the action is to be invoked. |
|
|
The EL path of the result returned by the associated method. |
|
< |
|
Identifies the update policy for the component. Valid values are |
|
Used internally by ADF. |
|
|
This is the class name for a |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
Refers to the |
|
|
Refers to the entry in the message bundle for this |
|
|
Wraps the data binding XML for the ADF Data Visualization pivot table component. |
|
|
|
Set to |
|
This is for backward compatibility to indicate which class implements the runtime for this binding definition.This is used by earlier versions of JDeveloper. |
|
|
Accesses the |
|
|
Used internally for testing purposes. |
|
|
This is the class name for a |
|
|
Used internally by ADF. |
|
|
Indicates the discriminator value for a hierarchical type binding (type definition for a tree node). This value is used to determine whether a given row in a collection being rendered in a polymorphic tree binding should be rendered using the containing hierarchical type binding. |
|
|
Unique identifier. May be referenced by any ADF action binding. |
|
|
Refers to the |
|
|
The data model used by ADF Tree components. |
adfc-config.xml
ADF Faces uses adfc-config.xml to store its configurations. It is an unbounded taskflow and the adfc-config.xml
file contains activies, control flow rules, and managed beans interacting to allow a user to complete a task.
The adfc-config.xml
file is the source file for the ADF unbounded task flow that JDeveloper creates by default when you create an application using the ADF Fusion Web Application template. By default, JDeveloper stores the adfc-config.xml
file in the following directory:
application_root
\ViewController\Web Content\WEB-INF
If you create additional unbounded task flows, JDeveloper proposes the following file name for the source files of the additional unbounded task flows:
adfc-config
N
.xml
where N is a number that increments each time you create a new unbounded task flow. Alternatively, you choose the file name you want for an unbounded task flow's source file.
Each source file for an unbounded task flow contains the metadata for activities, control flow rules, and managed beans that you added to an unbounded task flow so that end users can interact with the Fusion web application to complete a task.
The XML schema definition file (XSD) that defines valid metadata entries for the adfc-config.xml
file is adfc-config_1_0.xsd
. The adfc-config_1_0.xsd
file is stored in the adf-controller-schema.jar
file in the following directory of your JDeveloper installation:
jdev_install
\oracle_common\modules\oracle.adf.model_12.1.2
Use JDeveloper's XSD Visual Editor to view the adfc-config_1_0.xsd
file. Using this editor, you can identify the valid metadata elements and attributes for the adfc-config.xml
file.
The following example shows the source file for an unbounded task flow where view activities, control flow rules, and so on have yet to be added.
<?xml version="1.0" encoding="windows-1252" ?> <adfc-config xmlns="http://xmlns.oracle.com/adf/controller" version="1.2"> </adfc-config>
Figure A-4 shows the Diagram view of the Summit sample application for ADF task flows' adfc-config.xml
file. Example A-3 shows the corresponding source view of the unbounded task flow that appears in Figure A-4.
For more information about unbounded task flows, see Getting Started with ADF Task Flows .
Figure A-4 Diagram View of Summit ADF Task Flow Sample Application´s adfc-config.xml File

Example A-3 Source View of Summit ADF Task Flow Sample Application´s adfc-config.xml File
<?xml version="1.0" encoding="windows-1252" ?> <adfc-config xmlns="http://xmlns.oracle.com/adf/controller" version="1.2"> <view id="index"> <page>/index.jsf</page> </view> <managed-bean id="__1"> <managed-bean-name>login</managed-bean-name> <managed-bean-class>oracle.summit.bean.LoginBean</managed-bean-class> <managed-bean-scope>request</managed-bean-scope> </managed-bean> <managed-bean id="__2"> <managed-bean-name>WelcomePageBean</managed-bean-name> <managed-bean-class>oracle.summit.bean.WelcomePageBean</managed-bean-class> <managed-bean-scope>request</managed-bean-scope> </managed-bean> </adfc-config>
task-flow-definition.xml
The task-flow-definition.xml file stores metadata definition for a bounded task flow. You can specify the task flow definition XML filename and location when you generate the task flow.
The default file name that JDeveloper proposes for the source file of the first ADF bounded task flow that you create is task-flow-definition.xml
. This file stores the metadata for a bounded task flow. It contains entries for each view activity, method call activity, task flow call, and so on that you add to the bounded task flow.
JDeveloper proposes the following file name for subsequent bounded task flows that you create:
task-flow-definition
N
.xml
where N is a number that increments each time you create a new bounded task flow. Alternatively, you choose the file name you want for a bounded task flow's source file. By default, JDeveloper stores the task-flow-definition.xml
file in the following directory:
application_root
\ViewController\Web Content\WEB-INF
The XML schema definition files (XSD) that define the valid metadata entries for the source file of a bounded task flow are stored in the adf-controller-schema.jar
file in the following directory of your JDeveloper installation:
jdev_install
\oracle_common\modules\oracle.adf.model_12.1.2
Use JDeveloper's XSD Visual Editor to view these XSD files and identify the valid metadata elements and attributes for the source file of a bounded task flow.
The following example shows the content of a source file when you create a new bounded task flow using the Create Task Flow dialog. The <task-flow-definition>
element identifies this file as a bounded task flow. JDeveloper generates the <task-flow-definition>
element when you select the Create as Bounded Task Flow checkbox in the Create Task Flow dialog. The value of the <task-flow-definition>
element's id
attribute (task-flow-definition
) corresponds to the value that you enter in the Task Flow ID field of the Create Task Flow dialog. The <use-page-fragments/>
element indicates that all view activities in this bounded task flow must be associated with page fragments. JDeveloper generates this entry when you select the Create with Page Fragments checkbox in the Create Task Flow dialog.
<?xml version="1.0" encoding="windows-1252" ?> <adfc-config xmlns="http://xmlns.oracle.com/adf/controller" version="1.2"> <task-flow-definition id="task-flow-definition"> <use-page-fragments/> </task-flow-definition> </adfc-config>
Example A-4 shows the Summit ADF task flow sample application's customers-task-flow-definition.xml
file. You can view entries for the activities shown in the Structure window in Figure A-5. See Getting Started with ADF Task Flows .
Figure A-5 Structure View of the customers-task-flow-definition.xml File

Description of "Figure A-5 Structure View of the customers-task-flow-definition.xml File"
Example A-4 Source View of the customers-task-flow-definition.xml File
<?xml version="1.0" encoding="windows-1252" ?> <adfc-config xmlns="http://xmlns.oracle.com/adf/controller" version="1.2"> <task-flow-definition id="customer-task-flow-definition"> <default-activity id="__1">isCustomerLogin</default-activity> <managed-bean id="__11"> <managed-bean-name id="__9">CustomersBackingBean</managed-bean-name> <managed-bean-class id="__10">oracle.summit.backing.CustomersBackingBean</managed-bean-class> <managed-bean-scope id="__8">backingBean</managed-bean-scope> </managed-bean> <view id="Customers"> <page>/customers/Customers.jsff</page> </view> <method-call id="SetCurrentRowWithKeyValue"> <method>#{bindings.setCurrentRowWithKeyValue.execute}</method> <outcome> <fixed-outcome>setCurrentRowWithKey</fixed-outcome> </outcome> </method-call> <router id="isCustomerLogin"> <case id="__4"> <expression>#{securityContext.userInRole['Application Customer Role']}</expression> <outcome>customerLogin</outcome> </case> <default-outcome>notCustomerLogin</default-outcome> </router> <control-flow-rule id="__2"> <from-activity-id>SetCurrentRowWithKeyValue</from-activity-id> <control-flow-case id="__3"> <from-outcome>setCurrentRowWithKey</from-outcome> <to-activity-id>Customers</to-activity-id> </control-flow-case> </control-flow-rule> <control-flow-rule id="__5"> <from-activity-id>isCustomerLogin</from-activity-id> <control-flow-case id="__6"> <from-outcome>notCustomerLogin</from-outcome> <to-activity-id>Customers</to-activity-id> </control-flow-case> <control-flow-case id="__7"> <from-outcome>customerLogin</from-outcome> <to-activity-id>SetCurrentRowWithKeyValue</to-activity-id> </control-flow-case> </control-flow-rule> <critical/> <use-page-fragments/> </task-flow-definition> </adfc-config>
adf-config.xml
The adf-config.xml file contains application-level settings, that manages the runtime infrastructure such as failover behavior for the ADF application modules, global fetch limit for all the view objects, caching of resource bundles, automated refresh of page bindings, and so on for your application.
JDeveloper generates the adf-config.xml
file when you create an application using the ADF Fusion Web Application template. JDeveloper stores this application-level descriptor file in the following directory:
application_root
\.adf\META-INF
In JDeveloper, you can locate the file in the Application Resources panel of the Applications window by expanding the Descriptors > ADF META-INF nodes.
The adf-config.xml
file specifies application-level settings that you define during development. You can use a deployment profile to specify settings that are used at application deploy time. You can change some of the settings at runtime using Oracle Enterprise Manager.
Examples of tasks that you can accomplish by changing settings in the adf-config.xml
file include the following:
-
Enable or disable the validation of ADF Controller metadata
-
Replicate memory scope if you deploy your Fusion web application in a clustered environment
-
Configure properties to manage the caching of resource bundles where your application uses EL expressions to retrieve strings at runtime from resource bundles
The properties that you can configure are:
-
initial-size
Specifies the initial number of resource bundles that your application can cache. The default value is
100
. -
max-size
Specifies the maximum number of resource bundles that your application can cache. The default value is
100
. -
load-factor
The default value is
0.75
. -
expire-time
The default value is
43200
seconds (12 hours).You specify these properties as attribute values of the
<resource-bundle-cache>
element in theadf-config.xml
file. Example A-5 demonstrates how you might configure these values for your application in theadf-config.xml
file.
As an alternative to configuring the caching of resource bundles in the
adf-config.xml
file, you can specify the resource bundle caching properties as parameters for the Java Virtual Machine (JVM). If you specify the properties as parameters for the JVM, the changes apply to all applications managed by the JVM. For this reason, consider configuring the resource bundle caching properties in theadf-config.xml
file for you application. Use the following property names if you decide to specify the resource bundle caching properties as parameters for the JVM:-
resource-bundle-cache-initial-size
-
resource-bundle-cache-max-size
-
resource-bundle-cache-load-factor
-
resource-bundle-cache-expire-time
-
At runtime, the Fusion web application loads the adf-config.xml
file from the META-INF
directory. If the Fusion web application finds more than one adf-config.xml
file, it stops loading the file and logs a warning.
The following tasks modify or require you to modify the adf-config.xml
file:
-
In the ADF Controller layer
-
Creating task flows
By default, the ADF Controller uses a user session level cache to store the application's unbounded task flow metadata. This enables support for user specific seeded customization or design time at runtime customization of unbounded task flow metadata in your application. Clear the Allow Unbounded Task Flow Customizations checkbox in the Controller page of the
adf-config.xml
's file overview editor to disable this behavior and set the value of the<allow-unbounded-task-flow-customizations>
element tofalse
. You can still have customizations of the unbounded task flow metadata in your application. However, these customizations are shared by all users of the application. For information about customizations, see Customizing Applications with MDS . For information about task flows, see Getting Started with ADF Task Flows . -
Configure an integer value for the
root-view-port-request-lock-timeout
property that specifies the number of seconds a request can hold a lock on the root view port before timing out and allowing other requests to acquire the lock. The default value is 600 seconds. For information about the root view port, see About View Ports and ADF Regions. -
Minimize the number of active root view ports in an application by specifying a value for the
<max-root-view-ports>
property. See Minimizing the Number of Active Root View Ports in an Application. -
Modify the number of events collected or stop the collection of events by ADF Controller. Both tasks involve configuring the value of the
<debug-history-size>
element in your application'sadf-config.xml
file. See Reporting Incidents to the Diagnostic Framework. -
Enabling implicit save points
-
Specify a bounded task flow that does not require authorization to invoke when a user attempts to invoke a bounded task flow in a region for which they do not have security permissions. See Handling Access to Secured Task Flows by Unauthorized Users.
-
Enable ADF Controller to track changes to ADF memory scopes and replicate the page flow scope and view scope within the server cluster. You must set the ADF Controller parameter
<adf-scope-ha-support>
in the application'sadf-config.xml
file totrue
. See How to Ensure Oracle ADF Receives Notifications From Managed Bean Changes .
-
-
In the ADF Model layer
-
Disable automatic partial page rendering as the default behavior for an application. This requires you to change the value for the
changeEventPolicy
attribute from the default value ofppr
:<defaults changeEventPolicy="ppr"/>
See What You May Need to Know About Partial Page Rendering and Iterator Bindings.
-
Configure all Query components in the user interface project to render input search fields using a bind variable.
See What You May Need to Know About Named Bind Variables in Search Forms.
-
Control the dispatch of contextual events
-
-
Persisting saved searches in MDS
-
Creating RESTful web services from ADF application modules and managing the release version identifiers of REST resources
See Creating ADF REST Resources Using the Application Module and see Versioning the ADF REST Resource.
-
Configuring ADF Business Components global settings
See Using Fetch Size to Limit the Maximum Number of Records Fetched for a View Object and How to Initialize the Data Model Project With a Database Connection.
-
Enabling or disabling Oracle ADF Security
-
Enabling seeded customizations
See How to Enable Seeded Customizations for User Interface Projects and How to Enable Seeded Customizations in Existing Pages.
-
Configuring change persistence
-
Enabling user customizations
Example A-5 shows example entries for an application's adf-config.xml
file.
Example A-5 Sample adf-config.xml File
<?xml version="1.0" encoding="windows-1252" ?> <adf-config xmlns="http://xmlns.oracle.com/adf/config" xmlns:sec="http://xmlns.oracle.com/adf/security/config"> <sec:adf-security-child xmlns="http://xmlns.oracle.com/adf/security/config"> <CredentialStoreContext credentialStoreClass= "oracle.adf.share.security.providers.jps.CSFCredentialStore" credentialStoreLocation="../../src/META-INF/jps-config.xml"/> <!-- The Configure ADF Security wizard modifies JaasSecurityContext settings --> <JaasSecurityContext initialContextFactoryClass= "oracle.adf.share.security.JAASInitialContextFactory" jaasProviderClass= "oracle.adf.share.security.providers.jps.JpsSecurityContext" authorizationEnforce="true" authenticationRequire="true"/> </sec:adf-security-child> <adf-controller-config xmlns="http://xmlns.oracle.com/adf/controller/config"> <savepoint-datasource>java:comp/env/jdbc/summit_adfDS</savepoint-datasource> <enable-implicit-savepoints>true</enable-implicit-savepoints> <unauthorized-region-taskflow>/WEB-INF/task-flow-definition.xml</unauthorized-region-taskflow> </adf-controller-config> <adf-faces-config xmlns="http://xmlns.oracle.com/adf/faces/config"> <persistent-change-manager> <persistent-change-manager-class> oracle.adf.view.rich.change.MDSDocumentChangeManager </persistent-change-manager-class> </persistent-change-manager> <taglib-config> <taglib uri="http://xmlns.oracle.com/adf/faces/rich"> <tag name="calendar"> <attribute name="activeDay"> <persist-changes>true</persist-changes> </attribute> </tag> <!-- Additional tags omitted to make this example concise --> <tag name="table"> <attribute name="filterVisible"> <persist-changes>true</persist-changes> </attribute> </tag> </taglib> </taglib-config> </adf-faces-config> <adf-mds-config xmlns="http://xmlns.oracle.com/adf/mds/config"> <mds-config xmlns="http://xmlns.oracle.com/mds/config" version="11.1.1.000"> <cust-config> <match path="/"> <customization-class name="oracle.adf.share.config.UserCC"/> </match> </cust-config> </mds-config> </adf-mds-config> <adf-adfm-config xmlns="http://xmlns.oracle.com/adfm/config"> <defaults rowLimit="100"/> <startup> <amconfig-overrides> <config:Database jbo.SQLBuilder="Oracle" jbo.locking.mode="optimistic"/> </amconfig-overrides> </startup> </adf-adfm-config> <!-- Properties to manage the caching of a resource bundle in your application --> <adf-resourcebundle-config xmlns="http://xmlns.oracle.com/adf/resourcebundle/config"> <applicationBundleName> path-to-resource-bundle/bundle-name </applicationBundleName> <resource-bundle-cache initial-size="20" max-size="100" expire-time="30000" load-factor=".75"/> <bundleList> <bundleId override="true"> package.BundleID </bundleId> </bundleList> </adf-resourcebundle-config> </adf-config>
adf-settings.xml
The adf-settings.xml file is used by ADF application developers to extend and customize the ADF lifecycle with custom ADF phase listeners.
The adf-settings.xml
file holds project-level and library-level settings such as ADF Faces help providers and ADF Controller phase listeners.
The configuration settings for adf-settings.xml
are fixed and cannot be changed during or after application deployment. There can be multiple adf-settings.xml
files in an application. The users of adf-settings.xml
files are responsible for merging the contents of their configuration.
JDeveloper creates an adf-settings.xml
file when you:
-
Create an application using the ADF Fusion Web Application template
-
Add ADF Page Flow (ADF Controller) as a feature to an existing project
By default, JDeveloper stores the adf-settings.xml
file in the following directory:
application_root\ViewController\src\META-INF
The following tasks modify or require you to modify the adf-settings.xml
file:
-
Registering a phase listener
-
Creating help for ADF Faces components
See Displaying Help for Components in Developing Web User Interfaces with Oracle ADF Faces.
For information about how to edit the adf-settings.xml
file, see How to Configure for ADF Faces in adf-settings.xml in Developing Web User Interfaces with Oracle ADF Faces.
Example A-6 shows a sample adf-setting.xml
file with settings configured for a phase listener and a help provider.
Example A-6 Sample adf-settings.xml File
<?xml version="1.0" encoding="windows-1252" ?> <adf-settings xmlns="http://xmlns.oracle.com/adf/config"> <adfc-controller-config xmlns="http://xmlns.oracle.com/adf/controller/config"> <lifecycle> <phase-listener> <listener-id>SummitPhaseListener</listener-id> <class>oracle.summit.listeners.SummitPhaseListener</class> </phase-listener> </lifecycle> </adfc-controller-config> <adf-faces-config> <help-provider prefix="MYAPP"> <help-provider-class>oracle.summit.MyHelpProvider</help-provider-class> <property> <property-name>myCustomProperty</property-name> <value>someValue</value> </property> </help-provider> </adf-faces-config> </adf-settings>
web.xml
The web.xml file is used as a deployment descriptor file by Java web applications to determine how URLs map to servlets, which URLs require authentication, and other information. This file is an XML document that defines everything about your ADF application that a server needs to know.
Oracle ADF has specific configuration settings for the standard web.xml
deployment descriptor file.
When you create a project in JDeveloper that uses JSF technology, a starter web.xml
file with default settings is created for you in the /WEB-INF
folder. To edit the file, double-click web.xml in the Applications window to open it in the XML editor.
The following must be configured in web.xml
for all applications that use JSF and ADF Faces:
-
ADF Library resource servlet and mapping: Serves up web application resources (images, style sheets, JavaScript libraries) from ADF Library JAR files on the application class path.
By default, static web application resources (including resources in ADF Libraries), such as images, have a staleness period setting of 364 days. This staleness period setting requests that the client not make a request to the server to validate the static web application resources until one of the following events occur:
-
Staleness period expires
-
Browser cache no longer contains the static resource
-
User executes a page refresh
If the client does make a request to the server and the resources have not changed, the server returns a HTTP 304 response (Not Modified) with no body.
You can override the staleness period setting of 364 days for all static web application resources in ADF Libraries by adding initialization parameters to the
web.xml
file. The following example demonstrates how to set these initialization parameters using a number of examples.<!-- Expires all static resources in 30 days --> <init-param> <param-name>expires</param-name> <param-value>60*60*24*30</param-value> </init-param> <!-- Expires static resources with the .js file extension in 1 day --> <init-param> <param-name>expires.js</param-name> <param-value>60*60*24</param-value> </init-param> <!-- Turns off staleness setting. Use for testing --> <init-param> <param-name>expires</param-name> <param-value>OFF</param-value> </init-param>
The following example shows the default file extensions. You can add additional file extensions by configuring the
extensions
parameter value to include the file extensions that you want. Note that you must prepend and append ".
" to the file extension. The example also shows how you specify visibility for cache control.<!-- Specify file extensions for a number of different file formats --> <init-param> <param-name>extensions</param-name> <param-value>.png.jpg.jpeg.gif.js.css.</param-value> </init-param> <!-- Specify visibility for cache control, for example --> <init-param> <param-name>visibility</param-name> <param-value>Public</param-value> </init-param>
-
-
JSF servlet and mapping: The servlet
javax.faces.webapp.FacesServlet
that manages the request-processing lifecycle for web applications utilizing JSF to construct the user interface. -
ADF Faces filter and mapping: A servlet filter to ensure that ADF Faces is properly initialized by establishing a
AdfFacesContext
object. This filter also processes file uploads.
The JSF servlet and mapping configuration settings are automatically added to the starter web.xml
file when you first create a JSF project. When you insert an ADF Faces component into a JSF page for the first time, JDeveloper automatically inserts the configuration settings for ADF Faces filter and mapping, and resource servlet and mapping. See ADF Faces Configuration in Developing Web User Interfaces with Oracle ADF Faces.
logging.xml
ADF Logger is integrated in the WebLogic enterprise manager, and gives you the flexibility to adjust your log-levels at runtime. You can configure the logging session by editing the logging.xml file.
ADF Logger is a diagnostic tool that you can use in JDeveloper to capture runtime traces messages when you debug an application. You configure the use of this tool by editing the logging.xml
file.
For information about the logging.xml
file and using the ADF Logger, see Using the ADF Logger.