This post will show how to create a Student Enrollment Application using MYSQL DB with Struts 2 framework. This is a simple application that aims to collect the input details from the user during signup, save the details in the MYSQL DB and authenticate the same during login.
1. Create Java Web Application Project
To begin with, in the IDE, create a Java Dynamic Web project for the application. While creating the dynamic web project, enable the checkbox to generate web.xml deployment descriptor.
The sample web application directory structure is shown below with a standard deployment descriptor web.xml
2. Modify web.xml
Modify the contents of the web.xml to include the following:
- A Struts Dispatcher named Struts Prepare and Execute Filter to handle both the preparation and execution phases of Struts dispatching process.
- A Filter mapping to map the dispatcher created in the above step that should be invoked when the client specifies the url matching the url pattern.
1 2 3 4 5 6 7 8 9 10 11 12 |
|
3. Add JARs to the project
Add the following JARs from the web (or their latest equivalent) to the WEB-INF/lib folder under WebContent directory in the project.
- asm-3.3.jar (for bytecode manipulation framework support)
- asm-commons-3.3.jar (for bytecode manipulation framework support)
- commons-fileupload-1.3.jar (for file upload capability to your servlets and web applications support)
- commons-io-2.0.1.jar (for library of utilities to assist with developing IO functionality)
- commons-lang-2.4.jar (for manipulation of core classes by providing helper utilities)
- commons-lang3-3.1.jar (for manipulation of core classes by providing helper utilities)
- freemarker-2.3.19.jar (for UI tag templates support)
- javassist-3.11.0.GA.jar (for JAVA programming ASSISTance support)
- mysql-connector-java-5.1.26-bin.jar (for MYSQL data access support)
- ognl-3.0.6.jar (for Object Graph Navigation Language (OGNL) support)
- struts2-bootstrap-plugin-1.6.1.jar (for Bootstrap support)
- struts2-convention-plugin-2.3.15.1.jar (for the zero configuration and naming convention support)
- struts2-core-2.3.15.1.jar (for Struts Framework library support)
- struts2-jquery-plugin-3.6.1.jar (for JQuery support)
- xwork-core-2.3.15.1.jar (for XWork 2 library support)
The sample lib folder structure is shown below with the necessary JARs added for the project.
4. Create JSP Files for Student Signup/Login
Create a folder named “content” under WEB-INF (This is where the jsp files will be created).
Create a file signup.jsp to include a form to get the input details like UserName, Password, FirstName, LastName, DateOfBirth and EmailAddress of the student. A snapshot of the signup page is as follows:
Next, create a file login.jsp to include a form with UserName and Password. A snapshot of the login page is as follows:
The main actions for this application are as follows:
- Signup (To Insert the Student Signup details into the Database)
- Login (To Verify the Student Login details from the Database)
In order to display a success (result) page after the login action is complete, create a login-success.jsp page to indicate the login success (The page name will follow the semantics: <action name>–<result name>.jsp). Similarly, to indicate a login failure (result), create a page login-failure.jsp (login is the action and failure is the result). Also create a signup-failure.jsp page to indicate the signup failure, possibly due to an already existing username (signup is the action and failure is the result). These are just pages used to display the contents – no processing logic involved.
This application uses twitter bootstrap http://getbootstrap.com/ and http://bootswatch.com/united/ as style sheets.
The Struts 2 UI component tags are used to create the page elements like the form, textfield, password and hidden fields. The Struts Bootstrap tags are used for the Twitter Bootstrap integration. The Struts jQuery tags are used to include the AJAX functionality of submitting the form outside from the modal window and to use the UI widgets like the datepicker.
A reference link to the files under WebContent folder of this application can be found at https://github.com/elizabetht/StudentEnrollmentWithStruts/tree/master/WebContent
5. Create packages
Create packages each for the Struts Actions(equivalent to Controller), Service, Repository and Model classes under the src folder. Also create package for the utilities class under the src folder.
A sample snapshot of the project after the package creation is as shown below:
6. Create class for Model Tier
Create a POJO class named Student.java inside the package com.github.elizabetht.model to include the details of the Student model entity.
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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
|
7. Create db.properties file
Create a file named db.properties under the src folder, where the properties of the MYSQL DB like url, username and password can be specified. Replace <include connection url> with the actual connection url for connecting to the MYSQL DB. Likewise, replace <include username> and <include password> with the actual username and password values.
1 2 3 4 |
|
8. Create utility class
Create a POJO class named DbUtil.java under the package com.github.elizabetht.util to include a helper class functionality that would load the db.properties file and get the database connection.
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 |
|
9. Create class for Repository tier
Create a Repository tier POJO class named StudentRepository.java under the package com.github.elizabetht.repository to support the database operations of saving the student details, verifying the student login details and checking if the username exists when a save is attempted.
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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 |
|
10. Create class for Service Tier
Create a Controller tier POJO class named StudentService.java inside the package com.github.elizabetht.service. This layer acts as a median between the Controller and Repository tier classes.
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 |
|
11. Create Action classes for Controller tier
Create a Controller tier POJO class named StudentController.java inside the package com.github.elizabetht.controller. This is where the routing logic of the application goes – whether a signup or login action is called. For simplicity sake, two separate action classes are created for each of the operation.
Each of the Action class has to implement the execute() method. Based on the String result returned from the execute() method of the action class, the appropriate view page is rendered.
In most cases, the action class is extended from the general ActionSupport class, which has a lot of easy to use convenient features. So, extend the ActionSupport class in the Action class, unless you have a reason not to!
The following snippet shows the SignupAction 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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 |
|
Similar to the SignupAction class, the LoginAction class also implements the execute() method as shown below
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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
|
The @Action annotation is used to specify the incoming requested URL and results to be rendered. For results other than SUCCESS (or the equivalent success string), the resulting view will be rendered based on the value of the result. For instance, in SignupAction class, if “failure” string is returned from the execute() method, the result will be appended to the @Action value (which is “signup”, in this case) and the signup-failure.jsp page will be rendered. Similarly, in LoginAction class, if “failure” string is returned from the execute() method, the login-failure.jsp page will be rendered.
If SUCCESS (or the equivalent success string) is returned from the execute() method, the actual value of action will be the resulting view, unless there are no results specified using the @Result annotation. For instance, in LoginAction class, there are no @Result annotations used and hence, login-success.jsp will be rendered when execute() method returns a SUCCESS string.
But if there are results specified with @Result annotation as in SignupAction class, the name and location given by the results array will determine the view rendered – in this case, login-input action will be rendered (which is in-turn, an action specified by the LoginAction class).
12. Add Validators to the Form Fields
As shown in the above snippets of SignupAction and LoginAction classes, add the following required validators to the setter methods for the fields.
@RequiredStringValidator is used to check that a String field is not empty.
@StringLengthFieldValidator is used to check that a String field is of the right length. It assumes that the field is a String. If neither minLength nor maxLength is set, nothing will be done.
@EmailValidator is used to check that a field is a valid e-mail address if it contains a non-empty String.
13. Create the DB Schema in a MYSQL DB
Connect to the MySQL DB which is to be used for this application and create a new DB Schema named studentEnrollment using the MySQL Workbench. This is necessary as the DB Schema name of studentEnrollment is specified in the db.properties file.
Once the studentEnrollment DB Schema is created, create a table named student inside the DB Schema using the CREATE TABLE statement as follows:
1 2 3 4 5 6 7 8 9 10 |
|
14. Deploying the Application on Tomcat Server
Once the above steps are complete and the project is successfully built, the Java web application is ready to deployed on the Tomcat Server 7.
The Java web application can be deployed locally by right clicking on the project and choosing the “Run As->Run on Server” option.
The same can be deployed remotely on any native server that supports Tomcat by copying the WAR file (Right click on the project and choose Export as WAR File option) to /var/lib/tomcat7 folder (or appropriate tomcat directory) and restarting the tomcat server.
15. Clone or Download code
If using git, clone a copy of this project here: https://github.com/elizabetht/StudentEnrollmentWithStruts.git
In case of not using git, download the project as ZIP or tar.gz file here: https://github.com/elizabetht/StudentEnrollmentWithStruts/releases/tag/1.4