This chapter includes the following sections:
Most of what you need to know to get started with your web interface is covered in Developing Web User Interfaces with Oracle ADF Faces. However, using the ADF Model layer for data binding instead of JSF managed beans provides additional functionality, such as the ability to declaratively bind components to your business services. For more information on what ADF Model can provide, see Using ADF Model in a Fusion Web Application.
This chapter provides a high-level overview of the web interface development process as detailed in the Faces guide, and also provides information about the additional functionality available when you use ADF Model data binding.
Following the development process outlined in Introduction to Building Fusion Web Applications with Oracle ADF, developing a web application with ADF Faces and using ADF Model for data binding involves the following steps:
Creating ADF Faces templates for your pages (optional)
Creating the individual pages and page fragments for regions to be used within a page
Creating any needed managed beans
Additionally, the lifecycle of a Fusion web application is different from that of a standard JSF or ADF Faces application. For more information about how the lifecycle works, see Understanding the Fusion Page Lifecycle .
Managed beans are Java classes that give you the flexibility to add UI level code to your pages and task flows. You can use them for functions such as front end data manipulation and event handling.
ADF Faces page templates provides structure, consistency, and reusability for building web pages. You can create a page template and apply it to several pages for a consistent look and feel. It saves you time and effort because you do not need to layout the same elements each time you create a page.
In the create-edit-orders-task-flow-definition, the ShuttleBean is used for code to support a shuttle component to shuttle the available products from the leading list to the selected products in the trailing list. The managed bean contains the code necessary to populate the available products list and the selected products list. Figure 29-1 shows the managed beans used in the create-edit-orders-task-flow-definition.
Figure 29-1 Managed Beans in the create-edit-orders-task-flow-definition

You may find it helpful to understand other Oracle ADF features before you configure or use the ADF Model layer. Additionally, you may want to read about what you can do with your model layer configurations. Following are links to other functionality that may be of interest.
For more information about using page templates, see Using ADF Model in a Fusion Web Application, and the "How to Create a Page Template" section of Developing Web User Interfaces with Oracle ADF Faces.
For more information about managed beans in a standard JSF application, see the Java EE tutorial on the Oracle Technology Network website (http://www.oracle.com/technetwork/java/javaee/overview/index.html). For more information about managed beans and scope values, see About Object Scope Lifecycles.
As you design the flow of your application, you can begin to think about the design of your pages. To ensure consistency throughout your application, you use ADF page templates. These page templates provide structure and consistency for other developers building web pages. Page templates typically contain static areas which cannot be changed when they are used, and dynamic areas, where developers can place content specific to the page they are building.
For example, a page template can provide a top area for branding and navigation, a bottom area for copyright information, and a center area for the main content of the page. Page developers do not need to do anything to the branding and copyright information when they use the template. They need only to develop the main content area.
In addition to using ADF Faces components to build a page template, you can add attributes to the template definition. These attributes provide placeholders for specific information that the page developer needs to provide when using the page template. For instance, if you have added an attribute for a welcome message and when page developers use this page template, they can add a different welcome message for each page.
You can also add facet references to the page template. These references act as placeholders for content on the page. Figure 29-2 shows a rendition of how facets can be used in a page template.
Figure 29-2 Facets in the Page Template

In this page template, facet references are used inside four different panelSplitter components. When the home page was created using this page template, the navigational links were placed in the Header facet and the accordion panels that hold the navigation trees and search panels were placed in the Start facet. The cart summary was placed in the End facet, and the main portion of the page was placed in the Center facet. The copyright information was placed in the Bottom facet.
When you choose to add databound components to a page template, an associated page definition file and the other metadata files that support ADF Model layer data binding are created. Each component is bound in the same fashion as for standard JSF pages, as described in Using ADF Model in a Fusion Web Application. You can also create model parameters for the page template. The values for these parameters can then be set at runtime by the calling page.
For example, if you wanted a list of products to appear on each page that uses the page template, you could drag and drop the Name attribute of the ProductVO collection as a list. Or, if you wanted the pages to display the currently selected product Id, you could create a model parameter for the page template that would evaluate to that product's Id.
Note:
Page templates are primarily a project artifact. While they can be reused between projects and applications, they are not fully self-contained and will always have some dependencies to external resources, for example, any ADF data binding, Strings from a message bundle, images, and managed beans. 
If a page template does not contain databound components, it can be referenced dynamically by the calling page using an EL expression. That is, the page template to be used can be determined at runtime. For instance, a page may use templateA or templateB based on user selection. When you add a page template to a page, an af:pageTemplate tag is added to the page. The af:pageTemplate tag includes a viewId attribute that specifies the page template the page will use. You can set viewId with an EL expression to a managed bean method that returns the page template Id, as shown in the following example.
<af:pageTemplate
    id="pt1"
    viewId="#{myBean.templateViewId}"
If the page template has databound components, setting the viewId with an EL expression is not enough. Because databound components require access to the binding container, you must specify the page template as well as its associated binding container.
For databound page templates, you use the pageTemplateModel to manage both the page template Id and the associated binding container. In the JSF page, instead of using the viewId attribute, you set the value attribute to the pageTemplateModel. You must also modify the page executable section of the calling page's page definition file and create a managed bean with methods to process the page template Ids. For detailed instructions, see How to Add a Databound Page Template to a Page Dynamically.
Creating a page template for use in an application that uses ADF Business Components and ADF Model layer data binding is the same as creating a standard ADF Faces page template, as documented in the "Using Page Templates" section of Developing Web User Interfaces with Oracle ADF Faces. Once you create the template, you can drag and drop items from the Data Controls panel. JDeveloper automatically adds the page definition file when you drag and drop items from this panel.
The Create a Page Template wizard also allows you to create model parameters for use by the template.
Before you begin:
It may help to understand the options that are available to you when you create a basic page template. For more information, see Using Page Templates.
You may also find it useful to understand additional functionality that can be used with page templates. For more information, see Additional Functionality for Page Templates and Managed Beans.
You will need to complete this task:
To add model parameters to a template:
You can now use the Data Controls panel to add databound UI components to the page, as you would for a standard JSF page, as described in the remaining chapters in this part of the book.
Note:
If your template contains any method actions bound to a method iterator, you cannot change the value of the refresh attribute on the iterator to anything other than Default. If set to anything other than Default, the method will not execute.
When you add ADF databound components to a template or create model parameters for a template, a page definition file is created for the template, and any model parameters are added to that file.
Note:
This section describes what happens for a statically assigned page template. For information about dynamic templates, see How to Add a Databound Page Template to a Page Dynamically.
The following example shows what the page definition file for a template for which you created a productId model parameter might look like.
<parameters>
  <parameter id="productID" readonly="true"
             value="#{bindings.productId.inputValue}"/>
</parameters>
<executables/>
<bindings/>
Parameter binding objects declare the parameters that the page evaluates at the beginning of a request. For more information about binding objects and the ADF lifecycle, see Using ADF Model in a Fusion Web Application. However, since a template itself is never executed, the page that uses the template (the calling page) must access the binding objects created for the template (including parameters or any other type of binding objects created by dragging and dropping objects from the Data Controls panel onto the template).
In order to access the template's binding objects, the page definition file for the calling page must instantiate the binding container represented by the template's page definition file. As a result, a reference to the template's page definition is inserted as an executable into the calling page's page definition file, as shown in the following example.
<executables>
  <page path="oracle.summt.view.pageDefs.MyTemplatePageDef"
        id="pageTemplateBinding"/>
</executables>
In this example, the calling page was built using the MyTemplate template. Because the page definition file for the MyTemplate template appears as an executable for the calling page, when the calling page's binding container is instantiated, it will in turn instantiate the MyTemplatePageDef's binding container, thus allowing access to the parameter values or any other databound values. 
Because there is an ID for this reference (in this case, pageTemplateBinding), the calling page can have components that are able to access values from the template. When you create a JSF page from a template, instead of you having to repeat the code contained within the template, you can use the af:pageTemplate tag on the calling page. This tag contains the path to the template JSF page.
Additionally, when the template contains any ADF data binding, the value of that tag is the ID set for the calling page's reference to the template's page definition, as shown in the following example.
<af:pageTemplate viewId="/MyTemplate.jspx"
                 value="#{bindings.pageTemplateBinding}".../>
You can dynamically add a page template without databound components by using an EL expression to select the page template. For more information on how to do this, see Using Page Templates.
You can also statically add a page template with databound components. For more information on how to do this, see How to Use ADF Data Binding in ADF Page Templates.
This section describes how to dynamically add a page template with databound components to a page. For more information, see Using Page Templates.
You use the pageTemplateModel to dynamically manage a page template and its binding container. You use an EL expression in the page definition file to set the page template Id. You create managed bean methods to return the page template Id.
Before you begin:
It may help to understand the options that are available to you when you create a basic page template. For more information, see Using Page Templates.
You may also find it useful to understand additional functionality that can be used with page templates. For more information, see Additional Functionality for Page Templates and Managed Beans.
You will need to complete this task:
To add a databound page template to a page dynamically:
When a page is created using a template that contains ADF data binding, like a page without a template, the page definition file is used to create the page. During the lifecycle, the binding container for page template is also created and the UI components and biding for both the page and template are processed.
Specifically, the following happens:
The calling page follows the standard JSF/ADF lifecycle, as documented in Understanding the Fusion Page Lifecycle . As the page enters the Restore View phase, the URL for the calling page is sent to the binding context, which finds the corresponding page definition file.
During the Initialize Context phase, the binding container for the calling page is created based on the page definition file.
During the Prepare Model phase, the page template executable is refreshed. At this point, the binding container for the template is created based on the template's page definition file, and added to the binding context.
The lifecycle continues, with UI components and bindings from both the page and the template being processed.
You can create pages either by double-clicking a view activity in a task flow or by using the New Gallery. When creating the page (or dropping a view activity onto a task flow), you can choose to create the page as a JSF JSP or as a JSF JSP fragment. JSF fragments provide a simple way to create reusable page content in a project, and are what you use when you wish to use task flows as regions on a page. When you modify a JSF page fragment, the JSF pages that consume the page fragment are automatically updated.
Note:
Although JDeveloper supports XHTML files to be used in applications that use Facelets, the faces-config.xml and adfc-config.xml diagrammers do not support XHTML. In order to add navigation to these files, you have to manually edit the code by clicking the Source tab.
When you begin adding content to your page, you typically use the Components window and Data Controls panel of JDeveloper. The Components window contains all the ADF Faces components needed to declaratively design your page. Once you have the basic layout components placed on the page, you can then drag and drop items from the Data Controls panel to create ADF Model databound UI components. The remaining chapters in this part of the book explain in detail the different types of databound components and pages you can create using ADF Model data binding.
You create web pages using the Create JSF Page dialog.
Before you begin:
It may be helpful to have an understanding of the different options when creating a page. For more information, see Creating a Web Page.
To create a web page:
For more information on the templates available and what happens when you create the page, see "Creating a View Page" section in Developing Web User Interfaces with Oracle ADF Faces.
When you create a new blank web page, the generated code might differ depending on the type of project you are working in and the tag libraries that have been imported in the project. For example, if you are working in a project created from the Custom Project template and you select the Create Blank Page option in the Create JSF page dialog, the generated code might not include ADF Faces tags as it would under similar circumstances in the UI project of an ADF Fusion Web Application workspace.
If you want to create a page without a pre-defined layout that includes ADF Faces tags, it might be easiest to select the Copy Quick Start Layout option in the Create JSF page dialog and select a simple layout. Selecting this option will trigger the importing of the ADF Faces tag library into the project. In addition, any subsequent pages that you create in the project, even those created with the Create Blank Page option selected, will use ADF Faces tags.
When creating web pages, you should have a plan for how you will apply security to them.
To secure a web page within the ADF Security framework, you actually secure the page's page definition file. If the page is within a bounded task flow, you secure the bounded task flow (and the security policies applied to that bounded task flow apply to all of the pages within the task flow). If a page is within a bounded task flow, you should not apply security policies to the page definition file, as that could enable a user to access the page directly.
For more information on securing web pages, see Defining ADF Security Policies.
Managed beans are Java classes that you register with the application using various configuration files. When the JSF application starts up, it parses these configuration files, and the beans listed within them are made available. The managed beans can be referenced in an EL expression, allowing access to the beans' properties and methods. Whenever a managed bean is referenced for the first time and it does not already exist, the Managed Bean Creation Facility instantiates the bean by calling the default constructor method on it. If any properties are also declared, they are populated with the declared default values.
Often, managed beans handle events or some manipulation of data that is best handled at the front end. For a more complete description of how managed beans are used in a standard JSF application, see the Java EE tutorial on the Oracle Technology Network website (http://www.oracle.com/technetwork/java/javaee/overview/index.html).
Best Practice
Use managed beans to store logic that is related to the UI rendering only. All application data and processing should be handled by logic in the business layer of the application. Similar to how you store data-related logic in the database using PL/SQL rather than a Java class, the rule of thumb in a Fusion web application is to store business-related logic in the middle tier. This way, you can expose this logic as business service methods, which can then become accessible to the ADF Model layer and be available for data binding.
In an application that uses ADF data binding and ADF task flows, managed beans are registered in different configuration files from those used for a standard JSF application. In a standard JSF application, managed beans are registered in the faces-config.xml configuration file. In a Fusion web application, managed beans can be registered in the faces-config.xml file, the adfc-config.xml file, or a task flow definition file. Which configuration file you use to register a managed bean depends on what will need to access that bean, whether or not it needs to be customized at runtime, what the bean's scope is, and in what order all the beans in the application need to be instantiated. Table 29-1 describes how registering a bean in each type of configuration file affects the bean.
Note:
Fusion web applications take advantage of the functionality provided by ADF task flows. Managed beans accessed within the task flow definition must be registered in that task flow's definition file and not in the faces-config.xml file.
Table 29-1 Effects of Managed Bean Configuration Placement
| Managed Bean Placement | Effect | 
|---|---|
| 
 | 
 | 
| Task flow definition file | 
 | 
| 
 | 
 | 
As a general rule for Fusion web applications, a bean that may be used in more than one page or task flow, or one that is used by pages within the main unbounded task flow (adfc-config), should be registered in the adfc-config.xml configuration file. A managed bean that will be used only by a specific task flow should be registered in that task flow's definition file. There should be no beans registered in the faces-config.xml file.
Note:
If you create managed beans from dialogs within JDeveloper, the bean is registered in the adfc-config.xml file, if it exists.
For example, in the Summit sample application for Oracle ADF, the ShuttleBean is a managed bean used by the showshuttle page to handle the selections in the shuttle component on that page. Because it is used solely within the create-edit-orders-task-flow-definition task flow, it is registered in the create-edit-orders-task-flow-definition definition file. 
You can create a managed bean for use within a task flow (either the default adfc-config flow or any bounded task flow). For more information regarding managed beans and how they are used as backing beans for JSF pages, see the "Creating and Using Managed Beans" section in Developing Web User Interfaces with Oracle ADF Faces.
Within the editors for a task flow definition, you can create a managed bean and register it with the JSF application at the same time.
Before you begin:
It may help to understand the options that are available to you when you create a managed bean. For more information, see Using a Managed Bean in a Fusion Web Application.
You may also find it useful to understand additional functionality that can be used with managed beans. For more information, see Additional Functionality for Page Templates and Managed Beans.
You will need to complete this task:
faces-config.xml, adfc-config.xml, or a bounded task flow definition file. To create a managed bean for adfc-config.xml or a task flow:
When you use the configuration editor to create a managed bean and elect to generate the Java file, JDeveloper creates a stub class with the given name and a default constructor. The following example shows the code added to the MyBean class stored in the view package.
package view;
 
public class MyBean {
    public MyBean() {
    }
}
You now need to add the logic required by your task flow or page. You can then refer to that logic using an EL expression that refers to the managed-bean-name value given to the managed bean. For example, to access the myInfo property on the bean, the EL expression would be:
#{my_bean.myInfo}
JDeveloper also adds a managed-bean element to the appropriate task definition file. The following shows the managed-bean element created for the MyBean class. 
<managed-bean> <managed-bean-name>my_bean</managed-bean-name> <managed-bean-class>view.MyBean</managed-bean-class> <managed-bean-scope>session</managed-bean-scope> </managed-bean>
Typically, in an application that runs in a clustered environment, a portion of the application's state is serialized and copied to another server or a data store at the end of each request so that the state is available to other servers in the cluster.
Note:
If the managed bean will be calling set and get methods on ADF Faces components, you cannot serialize the managed beans because ADF Faces components are not serializable. You will need to access the ADF Faces components in another way. 
When you are designing an application to run in a clustered environment, you must:
Ensure that all managed beans with a lifespan longer than one request are serializable (that is, they implement the java.io.Serializable interface). Specifically, beans stored in session scope, page flow scope, and view scope need to be serializable.
Tip:
To identify failures with objects stored in page flow scope and view scope, use writeObject(). This method provides additional information in an exception about the object and scope that failed to serialize. Additional information might be a region's page flow scope and the key of the object. 
Make sure that the framework is aware of changes to managed beans stored in ADF scopes (view scope and page flow scope).
When a value within a managed bean in either view scope or page flow scope is modified, the application needs to notify the framework so that it can ensure that the bean's new value is replicated.
In this example, an attribute of an object in view scope is modified.
Map<String, Object> viewScope =
    AdfFacesContext.getCurrentInstance().getViewScope();
MyObject obj = (MyObject)viewScope.get("myObjectName");
Obj.setFoo("newValue");
Without additional code, the framework will be unaware of this change and it will not know that a new value needs to be replicated within the cluster. To inform the framework that an object in an ADF scope has been modified and that replication is needed, use the markScopeDirty() method, as shown in the following example. The markScopeDirty() method accepts only viewScope and pageFlowScope as parameters.
ControllerContext ctx = ControllerContext.getInstance(); ctx.markScopeDirty(viewScope);
This code is needed for any request that modifies an existing object in one of the ADF scopes. If the scope itself is modified by the scope's put(), remove(), or clear() methods, it is not necessary to notify the framework.
If an application is not deployed to a clustered environment, the tracking of changes to ADF memory scopes is not needed, and by default, this functionality is disabled. To enable ADF Controller to track changes to ADF memory scopes and replicate the page flow scope and view scope within the server cluster, set the <adf-scope-ha-support> parameter in the adf-config.xml file to true. Because scope replication has a small performance overhead, it should be enabled only for applications running in a server-cluster environment.
The folllowing shows adf-scope-ha-support set to true in the adf-config.xml file.
<?xml version="1.0" encoding="US-ASCII" ?>
<adf-config xmlns="http://xmlns.oracle.com/adf/config"
      xmlns:adfc="http://xmlns.oracle.com/adf/controller/config">
   <adfc:adf-controller-config>
   ...
    <adfc:adf-scope-ha-support>true</adfc:adf-scope-ha-support>
   ...
  </adfc:adf-controller-config>
   ...
</adf-config>