Create JSF + Primefaces Web Application
My tutorial is about how to use Eclipse + Maven + JSF + Primefaces and
create easily and quickly a basic framework for a web application.
This tutorial is divided in the following chapters:
- Create a Maven Project
- Install the JSF libraries
- Install Primefaces libraries
- Extend web.xml
- Test page
- Create and deploy the Web Application
Create a Maven Project
First we create a Maven project with Eclipse.
For this purpose we go to Eclipse on File -> New -> Maven Project
Maybe for some of you this option is not available. This is only the
case, if you have not installed Maven plugin for Eclipse. I use Eclipse
M2E.
First we select that we want to create a Maven Project.
At the next window, we click Next, since we are not interested in these settings.
On the next window we write in the box with the name filter: "webapp". Of course, without the quotes!
Here we select the following entry from the list of results and click Next.
Group ID: org.apache.maven.archetype
Artifact Id archetpye-maven-webapp
Next, we will be asked to enter for the project, the group id and
artifact Id. If you are interested what this means exactly, please refer
to Maven.
After we have completed the values we click Finish!
Thus we have now created a simple framework for a Web Application. But
it lacks the JSF and the Pimefaces support, which will now install
successively.
Install JSF libraries
To use the JSF in Web Application we need to tell the application that we want to use JSF.
We gain this when entering into the Maven POM file (to be found in path)
the JSF libraries. The following list shows how the POM file looks
after entering the JSF libraries.
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>de.ertantoker</groupId> <artifactId>blog</artifactId> <packaging>war</packaging> <version>0.0.1-SNAPSHOT</version> <name>blog Maven Webapp</name> <url>http://maven.apache.org</url> <dependencies> <!-- JSF libraries --> <dependency> <groupId>com.sun.faces</groupId> <artifactId>jsf-api</artifactId> <version>2.1.7</version> </dependency> <dependency> <groupId>com.sun.faces</groupId> <artifactId>jsf-impl</artifactId> <version>2.1.7</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> </dependencies> <build> <finalName>blog</finalName> </build> </project>
Install Primefaces libraries
As a next step we will install the Primefaces Libraries in the Project.
We can again achieve this with Maven, by entering the Primefaces
Libraries in the POM file. We only have to ensure that the Primefaces
repository is also shown. This is necessary because Primefaces can not
be found on any of the standard Maven repositories.
After entering the repository and the Primefaces Library the POM file is as follows:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>de.ertantoker</groupId> <artifactId>blog</artifactId> <packaging>war</packaging> <version>0.0.1-SNAPSHOT</version> <name>blog Maven Webapp</name> <url>http://maven.apache.org</url> <repositories> <repository> <id>prime-repo</id> <name>Prime Repo</name> <url>http://repository.primefaces.org</url> </repository> </repositories> <dependencies> <!-- JSF libraries --> <dependency> <groupId>com.sun.faces</groupId> <artifactId>jsf-api</artifactId> <version>2.1.7</version> </dependency> <dependency> <groupId>com.sun.faces</groupId> <artifactId>jsf-impl</artifactId> <version>2.1.7</version> </dependency> <!-- Primefaces libraries --> <dependency> <groupId>org.primefaces</groupId> <artifactId>primefaces</artifactId> <version>3.4</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> </dependencies> <build> <finalName>blog</finalName> </build> </project>
Now Primefaces and JSF are available for the Web Application.
Expand web.xml
In order that the Web Application can also use JSF, we must enter the
FacesServlet in the web.xml file. The file can be found as follows "/
src / main / webapp / WEB-INF / web.xml"
The Maven archetype with which we have created a Web Application
framework was unfortunately not up to date. Therefore, I have completely
recreated the web.xml with the following values:
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> <display-name>PrimeFaces Web Application</display-name> <!-- Welcome --> <welcome-file-list> <welcome-file>index.xhtml</welcome-file> </welcome-file-list> <!-- JSF Servlet --> <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>*.xhtml</url-pattern> </servlet-mapping> </web-app>
Please take care that you later use a servlet container or application
server that supports the servlet specification 2.5. In the generated
web.xml release 2.3 was mentioned as specification.
Thus the JSF servlet is entered
Create Test Page
Next we will create a simple test page, where we will use a default JSF component and a Primefaces component.
The test page is intentionally designed simply, because in the tutorial
it is not about how to create JSF + Primefaces pages, but about how to
create a Maven + JSF + Primefaces Project.
In my other tutorials on my blog I will provide you some more examples how to create JSF + Primefaces Appaplikationen.
We now create in ROOT directory (/ src / main / webapp /) of the web application a test page with the name index.xhtml.
The test page looks like this:
<html xmlns="http://www.w3c.org/1999/xhtml" xmlns:h="http://java.sun.com/jsf/html" xmlns:p="http://primefaces.org/ui"> <h:head> </h:head> <h:body> <div> <p>This is a default JSF button</p> <h:commandButton value="JSF Button" /> </div> <div> <p>This is a Primefaces button with icon</p> <p:button icon="star" value="Primeface Button"/> </div> </h:body> </html>
.
On the test page, a standard JSF button and a Primefaces button has been placed.
Create and deploy the Web Application
Next, we will create the web application. Thanks to Maven we can
comfortable create the web application. For this we need nothing more
than a Maven installation or if you want to start it with Eclipse one
Maven plug-in, which already includes Maven.
For more information about Maven please refer to the website of Maven.
The application is created with the following command.
mvn clean package
The web application is saved by default under the following directory:
/ target / blog.war
If you have given your project a different Artifact ID, then you will
find a WAR file with the name which you have registered as Artifact Id.
Finally, only the deployment of the web application remains. I will use
Tocat 7 for the deployment. There is no question that you can deploy the
web application on other servlet containers and application servers but
you should make sure that they also support the corresponding servlet
version, which is entered in the web.xml.
The deployment will take place as follows. You start the Tomcat servlet
container and copy the "blog.war" (The name can vary, see above) in
%TOMCAT_HOME% / webapp /
Thus the Application is deployed automatically.
Next we call in our browser of choice, the following URL:
http://localhost:8080/blog/index.xhtml (note the 8080 is only a default
Tomcat installation, depending on the installation, the port number can
vary)
Now if you see a website like this, you did everything right :-)
No comments:
Post a Comment