Java EE 7: Applying JSF 2.2 Faces Flows in a Web Application
Overview
- Java Platform, Standard Edition 7 (Java SE 7; Java SE 7u11 recommended)
- NetBeans 7.3.1 IDE for Java Platform, Enterprise Edition 7 (Java EE 7)
- GlassFish 4
- Have some experience writing and deploying JSF web applications.
- Have some experience with CDI beans.
- Have installed NetBeans 7.3.1, Java EE 7, and GlassFish 4.
- Have started NetBeans.
- Have unzipped the
FaceFlowExampleApp.zip
file. - Have opened the
FaceFlowExampleApp
project in NetBeans.
Purpose
This tutorial covers the steps required to apply the Java
Server Faces 2.2 (JSF 2.2) Faces Flow feature in a customer
registration procedure for a web application.
Time to Complete
Approximately 45 minutes
Introduction
JSF technology is a user interface (UI) framework for developing Java web applications. It is based on components, events, and Model-View-Controller (MVC) architecture. Faces Flow provides an encapsulation of related views and pages. Each flow has a well-defined entry and exit point for which the developer assigned an application-specific meaning.
It takes the best part of other flow-based technologies, such as ADF Task Flow, Spring Web Flow, and Apace MyFaces CODI, and standardizes them in JSF 2.2.
Scenario
In this tutorial, you modify a sample web application, which has a customer registration use case. A customer enters information on several pages.
In this web application, the navigation between pages for entering customer information, customer address, contact information, and a summary page makes a flow. All pages and objects that deal with the customer registration process can be composed as modules. An application thus become a collection of flows instead of just views.
Contexts and Dependency Injection (CDI) defines the
conversation scope to be used in such a scenario. Faces Flows
are a good replacement for conversation scope in this scenario
because they reduce code complexity and make configuration
simpler.
Hardware and Software Requirements
The following is a list of hardware and software requirements:
Prerequisites
Before starting this tutorial, you should:
Examining the FaceFlowExampleApp
Project
- On the home page, click the Customer Registration link to open the Customer Registration: Details page. This page is the first among the series of pages that are part of the customer registration process.
- Click the links or the buttons to navigate to each page.
- Enter the details on each page and click the Summary link or Finish button. The Summary page displays the customer details in a single view.
Complete the following steps to run and examine the FaceFlowExampleApp
project.
On the Projects tab in NetBeans, right-click the FaceFlowExampleApp project and select Run.
The home page opens in a web browser window.
data:image/s3,"s3://crabby-images/33f05/33f056fa93d2764389a2b3bb96f048a84af3707c" alt="images/t10101.jpg"
Perform the following steps:
data:image/s3,"s3://crabby-images/198d6/198d63ffc088bb1dc91affcc0971f8c21b8dfdd5" alt="images/t10102.jpg"
data:image/s3,"s3://crabby-images/3f129/3f1295200cf37d6ccd8cba6109c74d472793b69a" alt="images/t10103.jpg"
On the Projects tab in NetBeans, expand the FaceFlowExampleApp project and review the project directory structure.
Examine the xhtml pages in the Web Pages folder and the CDI beans in the com.example.beans package.
data:image/s3,"s3://crabby-images/9ec71/9ec712e0d467c6cc2c2b20bed5ce694b3bf6157d" alt="images/t10104.jpg"
Notice that @SessionScoped
is used in the
beans. This is not required because the customer information
is needed only in the flow of the customer registration
process.
Defining the Registration
Flow
- Create a zero length XML file in the registration directory to add an empty flow definition file.
- Enter registration-flow.xml for the name of the XML file.
- Remove all text in the registration-flow.xml to make it absolutely empty.
- Ensure that the first file of the flow is named as
registration
.xhtml.
Complete the following steps to define a flow in FaceFlowExampleApp
project.
Managing the Views of the Flow
On the Projects tab in NetBeans, create a registration
folder in the Web Pages
node.
data:image/s3,"s3://crabby-images/579f1/579f18e4e9e192008589920c4c209dcf707fcdff" alt="images/t10105.jpg"
The name of the folder is the same as the name of the
flow.
Move the four facelets, custAddress.xhtml,
custContact.xhtml,
registration.xhtml,
and summary.xhtml,
from the Web Pages
folder to the
registration folder.
data:image/s3,"s3://crabby-images/1010a/1010a5ba5e0fc0bc8cf1259b10b50b05707cfec5" alt="images/t10106.jpg"
Any facelet views placed in the registration
directory are considered to be a part of that flow.
Declaring a Flow
A flow can be declared two ways: using XML syntax or using a builder API. In the case of an empty flow definition, the start node is a facelet view whose name is equivalent to the flow name.
Declare a flow in XML syntax:
data:image/s3,"s3://crabby-images/d041e/d041ed9578ff1281b02c31db5298fa35ac1bee71" alt="images/t10107.jpg"
Examine a sample code that shows how to declare a flow definition,.
In this OBE scenario, an empty flow definition
file suffices. The code is provided only for your
information.
data:image/s3,"s3://crabby-images/08227/082270c686d7a298b24154f639c715f4c65963b6" alt="images/t10107b.jpg"
Returning from the Flow
To return from a flow you need a return node.
Create an XHTML
page in the Web
Pages directory and name it registration-return.xhtml.
In the case of our empty flow definition, the end node
is the name of the flow, followed by the -return
string.
data:image/s3,"s3://crabby-images/67a0a/67a0a6ede952f962ce9da34b51113c4986389733" alt="images/t10108.jpg"
Modify the registration-return.xhtml
file to display a message that you are out of the registration flow.
data:image/s3,"s3://crabby-images/ef144/ef144ebe83857072bcd8a053328d821664f77939" alt="images/t10109.jpg"
Modify the summary.xhtml file to enable navigation out of the registration flow.
For the Finish and Cancel buttons, modify the value of the action attributes to registration-return.
data:image/s3,"s3://crabby-images/c03db/c03db0d51ec1b8c9dd6cb32478639427a008aa53" alt="images/t10110.jpg"
Faces Flows take full advantage of implicit navigation. With implicit navigation, there is no need to declare the navigation rules.
Modifying the Named Beans
- Replace the @SessionScoped
annotation with an
@FlowScoped ("registration")
annotation in ReregistrationBean.java. - Import the appropriate class.
To apply the @FlowScoped
annotation in the named
beans, complete the following steps.
On the Projects tab, expand FaceFlowExampleApp > Source Packages > com.example.beans.
Open the three files, Address.java, Customer.java, and RegistrationBean.java, in the code editor window.
data:image/s3,"s3://crabby-images/2e6b6/2e6b6f7bdc40cbb1bc94cf0866c4fac46667b859" alt="images/t10111.jpg"
Perform the following steps:
data:image/s3,"s3://crabby-images/a136b/a136b8f301da15cd5e146528ca22a6565f3d8e6a" alt="images/t10112.jpg"
Repeat step 3 for Customer.java and Address.java.
Running the FaceFlowExampleApp
Application
- On the home page, click the Customer Registration link to start a new Faces Flow.
- Enter the customer details, address, and contact information on the relevant pages, and then click the Summary link.
- On the Summary page, click Finish. The registration-return page opens.
To run the application and test the Faces Flow feature, complete the following steps.
On the Projects tab in NetBeans, right-click the FaceFlowExampleApp project and select Run.
The home page opens in a web browser window.
Click the Customer Registration link to enter the Registration flow. The start node of the flow opens.
data:image/s3,"s3://crabby-images/198d6/198d63ffc088bb1dc91affcc0971f8c21b8dfdd5" alt="images/t10102.jpg"
In accordance with the Faces Flow convention, the name of the start node is the same as the name of the flow. In this case, it is registration.xhtml.
Click the Cancel button to verify that you can return from the flow.
The registration-return page opens. The flow ends here.
data:image/s3,"s3://crabby-images/5d652/5d6520fb5110dfa50b5e2de19f1a9573d073a635" alt="images/t10113.jpg"
Perform the following steps:
Summary
- Design and define a simple Faces Flow
- Define a start node and an end node for a flow
- Define an empty flow definition file
- Apply the
@FlowScoped
annotation
- Oracle
blog about JSF 2.2 Face Flows
- JSR- 344, JSF 2.2 Specification
- The Java EE 7 Tutorial (The tutorial is an excellent source of information about the technologies included in Java EE 7.)
- To learn more about Java EE 7, visit other OBE tutorials in
the Oracle
Learning Library.
- Lead Curriculum Developer: Paromita Dutta
- Reviewer: Ed Burns
- Editor: Susan Moxley
- QA: Diganta Choudhury
In this tutorial, you learned how to:
Resources
The application in this tutorial uses JSF facelets and JSF 2.2 Faces Flow. To learn more about these technologies, see the following resources:
Credits