The article lists down steps one need to take in order to get up and running with Spring MVC 4 and Hibernate 4. The article will describe following three key aspects:
Following are key components/artifacts that would be required to create the web application which makes use of Spring MVC 4 for managing MVC and Hibernate as an ORM framework:
Following are key libraries and tools to download and get ready before start working apart from Java (used Java 7) :
Following are minimum required configuration files you would need to add in the WEB-INF folder:
Web.xml
Note some of the following XML blocks in the code below:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
id="WebApp_ID" version="3.1">
<display-name>HelloDynWebProject</display-name>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<!-- Spring Configuration -->
<servlet>
<servlet-name>spring</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>spring</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring-servlet.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- Config for accessing JS/CSS files from with JSP files -->
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.css</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.js</url-pattern>
</servlet-mapping>
</web-app>
Spring-servlet.xml
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-4.0.xsd">
<!-- Configuration describing the package consisting of all components -->
<context:component-scan base-package="com.vf.restaurants" />
<!-- Configuration defining views files -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix">
<value>/WEB-INF/views/</value>
</property>
<property name="suffix">
<value>.jsp</value>
</property>
</bean>
<!-- Database-related Configuration to connect with database -->
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource"
p:driverClassName="com.mysql.jdbc.Driver" p:url="jdbc:mysql://localhost:3306/docdb"
p:username="root" p:password="root" />
<!-- Hibernate-related Configuration -->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="configLocation">
<value>/WEB-INF/hibernate.cfg.xml</value>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
</bean>
<!-- Transaction related configuration for working with database -->
<tx:annotation-driven />
<bean id="transactionManager"
class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
</beans>
Hibernate.cfg.xml
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<mapping class="com.vf.restaurants.Doctor" />
</session-factory>
</hibernate-configuration>
Following are different steps (in detail) which would help you get up and running. General Configurations (Requisites)
Spring MVC Configuration & Code Samples
Before I go ahead describing several code samples & configurations, lets look at following diagram that describes request-response flow between views (JSPs pages) and controller classes.
Before representing the classes and describing them, lets take a look at the view, the hello.jsp file. Following is the code:
hello.jsp
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Insert title here</title>
<link rel="stylesheet" type="text/css" href="bootstrap/css/bootstrap.min.css">
<script src="bootstrap/js/bootstrap.min.js"></script>
</head>
<body>
<div class="container-fluid">
<div class="row-fluid">
<div class="span2">
<ul class="nav nav-list">
<li class="nav-header">Services</li>
<li class="active"><a href="#">New Restaurant</a></li>
</ul>
</div>
<div class="span10">
<form class="form-horizontal" method="post" action="/HelloDynWebProject/createdoc">
<fieldset>
<legend>New Doctor</legend>
<label>Name</label>
<input type="text" name="name" placeholder="">
<label>Address</label>
<input type="text" name="address" placeholder="">
<div class="control-group" style="padding-top:20px">
<button type="submit" class="btn">Submit</button>
</div>
</fieldset>
</form>
</div>
</div>
</div>
</body>
</html>
After creating view file, create the controller class and related components (typical ones) such as following:
NewDoctorController
Pay attention to some of the following (primarily annotations) in the controller class code such as @Controller, @AutoWired. For now, you could add a dummy method addDoctor in DoctorDAO to complete the flow.
@Controller
public class NewDoctorController {
@Autowired
private NewDoctor newDoc;
@RequestMapping(value = "/newdoc", method = RequestMethod.GET)
public ModelAndView createDoctor( ModelMap model ) {
return new ModelAndView("hello");
}
@RequestMapping(value = "/createdoc", method = RequestMethod.POST)
public String createNewDoctor(Doctor doctor, ModelMap model) {
model.addAttribute("message", "Spring 3 MVC Hello World");
newDoc.addDoctor(doctor);
return "hello";
}
}
Doctor
Doctor class acts as a domain object that also maps to the database table which we will look into Hibernate section. Pay attention to following annotations.
@Entity
@Table(name = "doctor")
public class Doctor {
@Id
@Column(name="id")
@GeneratedValue
private Integer id;
@Column(name="address")
private String address;
@Column(name="name")
private String name;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
NewDoctor
This is a class consisting of business logic. Pay attention to @Component and @AutoWired annotation.
@Component
public class NewDoctor {
@Autowired
private DoctorValidation docVal;
@Autowired
private DoctorDAO docDAO;
public NewDoctor() {
}
public DocResult addDoctor( Doctor doc ) {
DocResult docResult = new DocResult();
if( docVal.validated( doc ) ) {
if( docDAO.persist( doc ) ) {
docResult.setSuccess( true );
docResult.setMessage( "success");
}
}
return docResult;
}
public DoctorValidation getDocVal() {
return docVal;
}
public void setDocVal(DoctorValidation docVal) {
this.docVal = docVal;
}
public DoctorDAO getDocDAO() {
return docDAO;
}
public void setDocDAO(DoctorDAO docDAO) {
this.docDAO = docDAO;
}
}
Once done adding above classes, go ahead and deploy the application. I would rather suggest you to do Debug as…Debug on Server and verify the request-response flow across different classes. Access the application at following link: http://localhost:8080/hellodynwebproject/newdoc. Enter the inputs and submit.
Hibernate Configuration & Code Samples
Following diagram represents two key aspects of hibernate configurations which is XML definitions for hibernate and mapping definitions (objects representing tables)
Add the hibernate.cfg.xml file (code shown above) within WEB-INF folder. Create a database with name as “docdb” and add following table:
CREATE TABLE IF NOT EXISTS `doctor` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`name` varchar(100) NOT NULL,
`address` varchar(200) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
DoctorDAO
Create DoctorDAO class. Pay attention to annotations such as @Component, @Transactional and @Autowired.
@Component
@Transactional
public class DoctorDAO {
@Autowired
private SessionFactory sessionFactory;
public boolean persist(Doctor doc) {
sessionFactory.getCurrentSession().save(doc);
return true;
}
}
Once done with above coding and db creation, redeploy and test the application at http://localhost:8080/hellodynwebproject/newdoc. Add name and address and submit. Check if the data got added in the database.
That is it! Let me know if you were able to get up and running using this article. Also, following is the link to download the eclipse project consisting of source code and config files. You may want to download Spring (& dependent) jars and Hibernate jars and put under WEB-INF/lib.
Source code for HelloDynWebProject
[adsenseyu1]
Artificial Intelligence (AI) agents have started becoming an integral part of our lives. Imagine asking…
In the ever-evolving landscape of agentic AI workflows and applications, understanding and leveraging design patterns…
In this blog, I aim to provide a comprehensive list of valuable resources for learning…
Have you ever wondered how systems determine whether to grant or deny access, and how…
What revolutionary technologies and industries will define the future of business in 2025? As we…
For data scientists and machine learning researchers, 2024 has been a landmark year in AI…