JavaData & JavaGetting Started with an MVC Application with JBoss Seam

Getting Started with an MVC Application with JBoss Seam

JBoss Seam is a Java EE-based framework that provides a uniform component model for all the business logic in a Web application and integration between the presentation and the business logic layers. JBoss Seam provides fine-grained state management with its new state contexts. Seam introduces the conversation context, which spans across multiple requests, making it feasible for a user to carry on multiple conversations concurrently, a conversation being a unit of  user interaction with an application. The HTTP Session also preserves state across requests, but the state from multiple interactions with an application is not isolated; conversations are not demarcated, and no conversation context is provided. JBoss Seam provides the business process context for long-running business processes consisting of multiple interactions with multiple users. In this tutorial, we shall create a JBoss Seam Model View Controller (MVC) application consisting of an EJB 3.0 entity bean, a stateful session bean, and a JSF user interface.

This tutorial has the following sections.

  • Setting the Environment
  • Creating a JBoss Seam Web Project
  • Creating the JBoss Seam Deployment Structure

Setting the Environment

We need to install the following software:

  • JBoss Application Server 7
  • MySQL 5.6 Database (Community Edition)
  • Eclipse IDE for Java EE Developers
  • JBoss Tools (installed as a plug-in to Eclipse
  • Apache Maven (version 3.4 or later)
  • Java 7

Set the environment variables JAVA_HOME, JBOSS_HOME, MAVEN_HOME, and MYSQL_HOME. Add %JAVA_HOME%/bin, %MAVEN_HOME%/bin, %JBOSS_HOME%/bin and %, and MYSQL_HOME to the PATH environment variable.

Creating a JBoss Seam Web Project

In this section, we shall create a Seam Web project. Select File|New. In New, select Seam|Seam Web Project. Click Next.

Seam01
Figure 1: Selecting a new project

The New Seam Project wizard gets started. Specify a Project name (catalog), select Target runtime as JBoss 7.1 Runtime, and select Dynamic web module version as 2.5. Click Next.

Seam02
Figure 2: Selecting catalog

Configure the Java settings; select Source folders on build path as src and the Default output folder as build/classes. Click Next.

Seam03
Figure 3: Configuring the Java settings

For the Web Module settings, specify Context root as catalog, and Content directory as WebContent. Select Generate web.xml deployment descriptor and click Next.

Seam04
Figure 4: Configuring the Web Module settings

For JSF Capabilities, select JSF Implementation Library as Library Provided by Target Runtime. Select Configure JSF servlet in the deployment descriptor. Select the default settings for JSF Configuration File (/WEB-INF/faces-config.xml), JSF Servlet Name (Faces Servlet), JSF Servlet Class Name (javax.faces.webapp.FacesServlet), and URL Mapping Patterns (*.seam).

Seam05
Figure 5: Selecting the JSF Implementation Library

Next, configure the Seam Facet. Select Deploy as EAR. To add a Seam Runtime, click Add. In Home Folder, select the folder in which the JBoss Seam 2.2.0 is installed. Specify a Name (jboss-seam-2.2.0) and click Finish.

Seam06
Figure 6: Configuring the Seam Facet

The Seam runtime gets configured. The EJB project name and the EAR project name get specified. In Libraries, select Copy Libraries from Seam Runtime. Select Database Type as MySQL 5(InnoDB). To create a new Connection profile, click New.

Seam07
Figure 7: Configuring the Seam runtime

Select Connection Profile Type as MySQL and specify Name (MySQLConnection). Click Next.

Seam08
Figure 8: Selecting the Connection Profile Type

Next, specify the driver and connection details. Select the MySQL JDBC Driver. In Properties, specify Database as test, URL as jdbc:mysql://localhost:3306/test, Username as root, and the Password. Click Test Connection to test the connection. If the message Ping succeeded gets displayed, click Next.

Seam09
Figure 9: Specifying the driver and connection details

In Summary, click Finish.

Seam10
Figure 10: Clicking Finish

The new Connection Profile gets added. Click Finish.

Seam11
Figure 11: The Connection Profile is added

The Seam facet gets installed.

Seam12
Figure 12: The Seam facet is installed

This project is associated with a Seam Perspective. A Seam Web Project, catalog, gets created as shown in the Package Explorer.

Seam13
Figure 13: Associating the project with a Seam Perspective

We won’t be using the default Seam project. Delete all the files and directories from the project root folder catalog. Add the sample Seam project for this tutorial to the catalog folder. Select File|Refresh to add the sample Seam project to the Package Explorer.

Seam14
Figure 14: Deleting files and directories from the catalog project root folder

Next, we shall discuss each of the sub-projects catalog-ear, catalog-ejb, and catalog-web.

Creating the JBoss Seam Deployment Structure

Classloading in JBoss AS 7 is based on modules, with each module providing some class packages. Classes in one module are not available in another module. Some module dependencies are added by default to a JBoss application based on its requirements; for example, the Hibernate JPA API module is made available in a EJB 3.0 JPA application. The module dependencies added by default are the implicit module dependencies. The catalogcatalog-earsrcmainapplicationMETA-INFjboss-deployment-structure.xml file may be used for fine-grained class loading, such as add additional module dependencies or excluding some implicit module dependencies. Because we are using JSF 2.0, we need to exclude the JSF 1.2 modules and add the JSF 2.0 modules. Also, add the org.dom4j module. The jboss-deployment-structure.xml file is listed below.

<jboss-deployment-structure >
   <ear-subdeployments-isolated>false</ear-subdeployments-isolated>
   <deployment>
      <exclusions>
         <module name="javax.faces.api" slot="1.2"/>
         <module name="com.sun.jsf-impl" slot="1.2"/>
         <module name="org.jboss.integration.ext-content" slot="main"/>
      </exclusions>
      <dependencies>
         <module name="javax.faces.api" slot="main" export="true"/>
         <module name="com.sun.jsf-impl" slot="main" export="true"/>
         <module name="org.dom4j" export="true"/>
      </dependencies>
   </deployment>
</jboss-deployment-structure>

The jboss-deployment-structure.xml file is shown in the Project Explorer.

Seam15
Figure 15: The jboss-deployment-structure.xml file

We also need to create a MySQL datasource with JNDI MySQLDS. In the next article, we shall discuss creating an entity bean and a session bean façade.

Get the Free Newsletter!

Subscribe to Developer Insider for top news, trends & analysis

Latest Posts

Related Stories