tag
defines an input form. In a traditional HTML form, we have to set the METHOD and ACTION
attributes; but in JSF they are already predefined.
Inside the form, we find the tag called . It defines
a textual input element. It is identified, on the page, by its attribute id.
The attribute assignment: value="#{adata.inputWord}" binds the contents of this input
field "inputWord" to the value of the "adata" bean's string property.
4. Define data validation rules
It is defined, in the JSP page above, two data validation rules. The first is just to limit
the entry to a sentence with a nomber of characters between 10 and 25; the second validation
will print an error message if the variable's value fails validation. this validations rules
are set for the server-side; for the client-side validation runs as JavaScript in the Web
browser. The data valiadtion rules states for the Controller what to do when errors occur.
The previous section explained what the Controller does when it finds input validation errors. when
the inputs are valid, the Controller uses the action to perform the next task.
The inputText tag's "required" attribute set to "true" means that this field must
be filled. The "for" attribute (here inputWord) must match the id attribute of one of the
other components on the page. If a message is rendered, it will match element whose id is inputWord.
We can also use style (here color) inside the tag. Since JSF supports CSS, we can use class attributes.
5. Define View navigation for the Controller
In response to the user inputs, the Controller uses the event "action" to know which views to display.
The application (JSP page) includes also a <h:commandButton> tag in its form, that is the button
used to post the form to the Controller; for example:
<h:commandButton id="submit" action="validated" value="Submit"/>
The related rules are written in the page navigation "faces-config.xml". They are:
<navigation-rule>
<from-view-id>/jsp/firstPage.jsp</from-view-id>
<navigation-case>
<from-outcome>validated</from-outcome>
<to-view-id>/jsp/followingPage.jsp</to-view-id>
</navigation-case>
</navigation-rule>
If the controller receives valid inputs from a form in the page /jsp/firstPage.jsp,
and the action is 'validated', then it goes to page /jsp/followingPage.jsp.
6. Define the web descriptor: web.xml
A JSF application is a Web application. It requires then a web.xml deployment descriptor.
This descriptor needs a servlet mapping to map the JSF controller to the URL /faces/.
This directory /faces/ is replaced by *.jsf (all the files.jsp) when the controller
serves the .jsp files. The servlet mapping in the web.xml deployment descriptor could be:
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>/faces/* or *.jsf </url-pattern>
</servlet-mapping>
The related used WAR (Web Archive) files in JSF Reference Implementation include the
two libraries, jsf-api.jar and jsf-impl.jar, in its directory /WEB-INF/lib.
7. Run the application over the server
The application is started by running the /jsp/firstPage.jsp. The related server is
the Tomcat's sever. On a browser, the related URL is :
http://localhost:port#/jsp/firstPage.jsp, when \jsp\ is the immediate subdirectory of
\webapps\directory.
2. Installation
The steps:
1. Download the version of tomcat that fits the related JFS libraries. We will use
JFS-1.2, then Apache 6.0.13. Go to
>archive.apache.org
and download: the binary: apache-tomcat-6.0.13.zip, and the wizard apache-tomcat-6.0.13.exe
Unzip the file apache-tomcat-6.0.13.zip in a directory. Inside this same
directory place apache-tomcat-6.0.13.exe binary and double-click on it to
install Tomcat. Choose the port (here 8055). Tomcat is installed in the
directory: C:\Program Files\Apache Software Foundation\Tomcat 6.0
2. Go to
jakarta-taglibs
and download : jakarta-taglibs-standard-1.0.6.zip.
Unzip this file to have the directory
jakarta-taglibs-standard-1.0.6 that contains \lib directory which contains among the others
the two jar files jstl.jar and standard.jar
3. Go to
jsk12 Glassfish
and download : jsf-1.2_04-b10-p01.zip.
Unzip this file to have the directory
jsf-1.2_04-b10-p01 that contains \lib directory which contains among the others
the two jar files jsf-api.jar and jsf-impl.jar
4. Now, go to Tomcat directory, in : C:\Program Files\Apache Software Foundation\Tomcat 6.0\webapps
and create there a director (here JSF). Inside \JSF directory, create \WEB-INF directory. Inside this
\WEB-INF directory create \lib directory. Copy the four jar files: jstl.jar, standard.jar,
jsf-api.jar, and jsf-impl.jar in this \lib directory.
Now, the necssary programs are in place.
3. First example:
The steps:
1. Inside the directory \JSF, create two files:
index.jsp
<jsp:forward page="luck.jsf"/>
and luck.jsp:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<%@taglib uri="http://java.sun.com/jsf/html" prefix="h"%>
<%@taglib uri="http://java.sun.com/jsf/core" prefix="f"%>
<html>
<body>
<f:view>
<h:outputText value="Regards and all the best of luck."/>
</f:view>
</body>
</html>
2. Inside the directory \JSF\WEB-INF, create two files:
faces-config.xml
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE faces-config PUBLIC
"-//Sun Microsystems, Inc.//DTD JavaServer Faces Config 1.1//EN"
"http://java.sun.com/dtd/web-facesconfig_1_1.dtd">
<faces-config>
</faces-config>
and web.xml:
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd">
<web-app>
<!-- Faces Servlet -->
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup> 1 </load-on-startup>
</servlet>
<!-- Faces Servlet Mapping -->
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.jsf</url-pattern>
</servlet-mapping>
</web-app>
3. Lanch the application in the server. The output looks like this
first example with JSF
4. Second example:
In this example, we want just send a word and receive it via the server.
We construct a subdirectory \CONTACT\ under \webapps directory; then two
subdirectorie \jsf\ which contains :
contact.jsp (send file)
and
greetings.jsp (receive file);
and WEB-INF subdirectory that contains the files :
faces-config.xml;
and
>web.xml;
and \lib and \src subdirectories.
The \lib directory contains the jar files jsf-api.jar, jsf-impl.jar, jstl.jar,
standard.jar, and password.jar. The password.jar file is build by ant. The \src
directory contains \java directory which contains the
PasswordBean.java.
The directory \classes is built by ant and contains
PasswordBean.class.
The build.xml file compile PasswordBean.java and place PasswordBean.class
in the \class directory; build Passprd.jar and place it in the \lib\ directory.
To have a BuildFile built.xml file, go to
ant.apache.org.
and define aa example. Here is the BuidFile used here:
build.xml.
Now set the command-line at the directory where build.xml is present and run ant
to get this output:
build.xml on command line.
Run the application on the server to get:
>sending word,
and
receiving the related word.
5. Third example:
In this example we want to login in an account with parmission.
The steps are the same as in the second example, except that we need
also the servlet-api.jar file in the \WEB-INF\lib directory. Bring
it from Tomcat 6.0\lib directory.
Construct the directory
ExampleLogin.
under the \webapps directory.
\ExampleLogin contains:
login.jsp,
success.jsp,
and
failure.jsp,
and WEB-INF subdirectory, that contains:
faces-config.xml,
and
web.xml.
\lib contains ExampleLogin.jar, jsf-api.jar, jsf-impl.jar,
jstl.jar, loginExample.jar (by built.xml), servlet-api.jar, and
standard.jar.
\src\ contains:
build.xml.
\java with
ExampleLogin.java file.
and \classes with ExampleLogin.class (by buil.xml)
Compile with ant and browse the application to get:
The log in,
the case of succes:.
or the case of :
failure.