From the very beginning of this tutorial, the goal is to build a very simple web application in Struts 2. However, the tutorial covers also:
- where to download Java, Eclipse and Tomcat (this tutorial will not cover how to install Java, Eclipse or Tomcat);
- where to download Struts 2 framework;
- how to create a basic web project in Eclipse with Struts;
- how to run the project in Tomcat.
In what is next I plan to guide you through the steps to create a simple java web application with struts using Eclipse Mars IDE for MAC OS X and Tomcat 7 application server. This tutorial assumes you already have Java, Eclipse and Tomcat installed on your local machine. In case not, you can download them from the following sources:
- Java: http://www.oracle.com/technetwork/java/javase/downloads/index.html;
- Eclipse: https://eclipse.org/downloads/ (choose Eclipse IDE for Java EE Developers);
- Tomcat: https://tomcat.apache.org/download-70.cgi (I am using version 7).
Once again, the installation of the three falls outside the tutorial’s scope.
Struts 2 Requirements: Struts 2 requires Servlet API 2.4 or higher, JSP 2.0 or higher and JAVA 7 or higher.
Step 1: Create the project in eclipse
Open eclipse and go to File -> New -> Web Project. Near the name field enter the project name (we are going to call our application HelloDemo), choose a simple project template. Leave programming model selected as Java EE and click next button:
Choose the target runtime and context root of the HelloDemo application:
Click finish button.
Step 2: Download the struts framework and add the minimum configuration to your project
Forwards, download the struts distribution from apache and copy the minimal necessary jars to WebContent\WEB-INF\lib directory. At the time of this tutorial was written I used the struts-2.5 distribution. Therefore, the jars I copied to HelloDemo projects are:
- commons-fileupload-1.3.1.jar
- commons-io-2.4.jar
- commons-lang-2.4.jar
- commons-lang3-3.4.jar
- commons-logging-1.1.3.jar
- freemarker-2.3.23.jar
- javassist-3.20.0-GA.jar
- log4j-api-2.5.jar
- ognl-3.1.4.jar
- struts2-core-2.5.jar
Next step is to configure the Struts 2 framework into you project and for this you need to add the struts.xml configuration file (at java source level) and define the entry point of the Struts 2 framework in web.xml file.
Let’s start with the configuration of web.xml, as this is the entry point of any JAVA EE web application. In this file we are configuring the StrutsPrepareAndExecuteFilter filter (which is the entry point of a struts 2 application). Your web.xml file should look like:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
<?xml version="1.0" encoding="UTF-8"?> <web-app id="WebApp_ID" version="3.0" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"> <display-name>Hello Demo</display-name> <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.htm</welcome-file> <welcome-file>index.jsp</welcome-file> <welcome-file>default.html</welcome-file> <welcome-file>default.htm</welcome-file> <welcome-file>default.jsp</welcome-file> </welcome-file-list> <strong><filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping></strong> </web-app> |
Notice the filter and filter-mapping entries. These two entries are part of struts 2 framework configuration.
Let’s turn our attention to struts.xml file which contains the configurations for the struts actions. This is a mapping file which ties together the URL (the user action), the *Action.java class (the MODEL) and the jsp page (the VIEW) and it must be located under the WEB-INF\classes (hence we are going to create this file under the source folder of the project.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd"> <struts> <constant name="struts.devMode" value="true" /> <package name="hellodemo" extends="struts-default"> <action name="index"> <result>index.jsp</result> </action> </package> </struts> |
The above minimal configuration tells the Struts 2 framework that if the URL ends in index.action to redirect the browser to index.jsp.
I want to make a couple of points about the previous code:
- set the constant struts.devMode value=true to enable some useful struts 2 message logs;
- the package tag allows the separation and the modularization of the configuration;
- the result tag, determine what gets returned to the browser after an action is executed.
Let’s create an index.jsp page:
1 2 3 4 5 6 7 8 9 10 11 |
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Hello Demo - Application title</title> </head> <body> <h3>Hello Demo! First step done.</h3> </body> </html> |
Build your project, start your server and go to http://localhost:8080/HelloDemo/ in your preferred browser. Congrats! Your first struts 2 application is up and running. You will see:
Let’s not stop here, let’s have some fun and add a simulation login functionality to our HelloDemo application. We are doing this in four steps:
- Create a login.jsp page with a simple html form (user, password and submit button)
- Create a PerformLoginAction.java class which contains the logic to manage the successful login and failed login
- Create a jsp page forsuccessful login (dashboard.jsp) and another jsp page for failed login (wrongCredentials.jsp)
- Create an action in struts.xml for PerformLoginAction and tie it’s result to dashboard.jsp and wrongCredentials.jsp
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="performlogin"> <table> <tr> <td>Username:</td> <td><input type="text" name="username" value="" /> </tr> <tr> <td>Password:</td> <td><input type="password" name="pass" value="" /> </tr> <tr> <td> </td> <td><input type="submit" value="Login" /> </tr> </table> </form> </body> </html> |
Notice the form action=”performlogin”. This action is defined in struts.xml:
1 2 3 4 |
<action name="performlogin" class="org.code.programmers.PerformLoginAction" method="execute"> <result name="success">dashboard.jsp</result> <result name="error">wrongCredentials.jsp</result> </action> |
When this action is called, the execute method of PerformLoginAction starts. In this method will return success you will be redirected to dashboard.jsp, otherwise (in case error is returned) you will be redirected to worgCredentials.jsp. Let’s have a look at PerformLoginAction.java class:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
package org.code.programmers; import com.opensymphony.xwork2.ActionSupport; public class PerformLoginAction extends ActionSupport { String username; String password; public String execute() throws Exception { if ("John".equals(username) && password.equals("good")) { return SUCCESS; } else { return ERROR; } } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } } |
You can see, the success definition is username equals John and password equals good. In real life example, the things are different, the password would be encrypted and the values for username and password would be checked into a repository system (usually LDAP or a database). However, for the purpose of this tutorial the approach used is more adequate.
Following are the dashboard.jsp and wrongCredentials.jsp:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Hello Demo App - User Dashboard</title> </head> <body> <h2>Hi There</h2> <p>Welcome to this stupid login system.</p> </body> </html> |
1 2 3 4 5 6 7 8 9 10 11 12 |
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Hello Demo App - Wrong Credential Page</title> </head> <body> <h2>BOO !!!</h2> <p>You entered wrong credentials. Go back to <a href="./login.action">login</a> page.</p> </body> </html> |
The end !
Summary
In this tutorial I guide you into the creation of a simple web application using Struts 2 framework.
Now that you have a taste of how to use Struts 2 framework in your application, I will extend, in a further post, this application to use database capabilities
1 Comment