本文是開發基於spring的web應用的入門文章,前端采用Struts MVC框架,中間層采用spring,後台采用Hibernate。
本文包含以下內容:
·配置Hibernate和事務
·裝載Spring的applicationContext.xml文件
·建立業務層和DAO之間的依賴關系
·將Spring應用到Struts中
簡介
這個例子是建立一個簡單的web應用,叫MyUsers,完成用戶管理操作,包含簡單的數據庫增,刪,查,該即CRUD(新建,訪問,更新,刪除)操作。這是一個三層的web應用,通過Action(Struts)訪問業務層,業務層訪問DAO。圖一簡要說明了該應用的總體結構。圖上的數字說明了流程順序-從web(UserAction)到中間層(UserManager),再到數據訪問層(UserDAO),然後將結果返回。
Spring層的真正強大在於它的聲明型事務處理,幫定和對持久層支持(例如Hiberate和iBATIS)
以下下是完成這個例子的步驟:
1.安裝Eclipse插件
2.數據庫建表
3.配置Hibernate和Spring
4.建立Hibernate DAO接口的實現類
5.運行測試類,測試DAO的CRUD操作
6.創建一個處理類,聲明事務
7.創建web層的Action和model
8.運行Action的測試類測試CRUD操作
9.創建jsp文件通過浏覽器進行CRUD操作
10.通過浏覽器校驗jsp
安裝eclipse插件
1.Hibernate插件http://www.binamics.com/hibernatesync
2.Spring插件http://springframework.sourceforge.net/spring-ide/eclipse/updatesite/
3.MyEclipse插件(破解版)
4.Tomcat插件. tanghan
5.其他插件包括xml,jsp,
數據庫建表
create table app_user(id number not null primary,firstname vchar(32),lastname vchar(32));
新建項目
新建一個web project,新建後的目錄結構同時包含了新建文件夾page用於放jsp文件,和源文件夾test用於放junit測試文件。同時將用到的包,包括struts,hibernate,spring都導入到lib目錄下。
創建持久層O/R mapping
1.在src/com.jandar.model下用hibernate插件從數據庫導出app_user的.hbm.xml文件改名為User.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd" >
<hibernate-mapping package="com.jandar.model">
<class name="User" table="APP_USER">
<id
column="ID"
name="id"
type="integer"
>
<generator class="assigned" />
</id>
<property
column="LASTNAME"
length="10"
name="lastname"
not-null="false"
type="string"
/>
<property
column="FIRSTNAME"
length="10"
name="firstname"
not-null="true"
type="string"
/>
</class>
</hibernate-mapping>
2.通過hibernate synchronizer->synchronizer file生成User.java文件,User對象對應於數據庫中的app_user表
注:在eclipse下自動生成的對象文件不完全相同,相同的是每個對象文件必須實現Serializable接口,必需又toString和hashCode方法;
import java.io.Serializable;
import org.apache.commons.lang.builder.EqualsBuilder;
import org.apache.commons.lang.builder.HashCodeBuilder;
import org.apache.commons.lang.builder.ToStringBuilder;
import org.apache.commons.lang.builder.ToStringStyle;
public class BaseObject implements Serializable {
public String toString() {
return ToStringBuilder.reflectionToString(this,
ToStringStyle.MULTI_LINE_STYLE);
}
public boolean equals(Object o) {
return EqualsBuilder.reflectionEquals(this, o);
}
public int hashCode() {
return HashCodeBuilder.reflectionHashCode(this);
}
}
public class User extends BaseObject {
private Long id;
private String firstName;
private String lastName;
/**
* @return Returns the id.
*/
public Long getId() {
return id;
}
/**
* @param id The id to set.
*/
public void setId(Long id) {
this.id = id;
}
/**
* @return Returns the firstName.
*/
public String getFirstName() {
return firstName;
}
/**
* @param firstName The firstName to set.
*/
public void setFirstName(String firstName) {
this.firstName = firstName;
}
/**
* @return Returns the lastName.
*/
public String getLastName() {
return lastName;
}
/**
* @param lastName The lastName to set.
*/
public void setLastName(String lastName) {
this.lastName = lastName;
}
}
創建DAO訪問對象
1.在src/com.jandar.service.dao新建IDAO.java接口,所有的DAO都繼承該接口
package com.jandar.services.dao;
public interface IDAO {
}
2.在src/com.jandar.service.dao下新建IUserDAO.java接口
public interface IUserDAO extends DAO {
List getUsers();
User getUser(Integer userid);
void saveUser(User user);
void removeUser(Integer id);
}
該接口提供了訪問對象的方法,
3.在src/com.jandar.service.dao.hibernate下新建UserDAOHiberante.java
import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.orm.hibernate.support.HibernateDaoSupport;
import com.jandar.model.User;
import com.jandar.service.dao.IUserDAO;
public class UserDaoHibernate extends HibernateDaoSupport implements IUserDAO {
private Log log=LogFactory.getLog(UserDaoHibernate.class);
/* (非 Javadoc)
* @see com.jandar.dao.IUserDAO#getUsers()
*/
public List getUsers() {
return getHibernateTemplate().find("from User");
}
/* (非 Javadoc)
* @see com.jandar.dao.IUserDAO#getUser(java.lang.Long)
*/
public User getUser(Integer id) {
// TODO 自動生成方法存根
return (User) getHibernateTemplate().get(User.class,id);
}
/* (非 Javadoc)
* @see com.jandar.dao.IUserDAO#saveUser(com.jandar.model.User)
*/
public void saveUser(User user) {
log.debug("xxxxxxx");
System.out.println("yyyy");
getHibernateTemplate().saveOrUpdate(user);
if(log.isDebugEnabled())
{
log.debug("userId set to "+user.getId());
}
}
/* (非 Javadoc)
* @see com.jandar.dao.IUserDAO#removeUser(java.lang.Long)
*/
public void removeUser(Integer id) {
Object user=getHibernateTemplate().load(User.class,id);
getHibernateTemplate().delete(user);
if(log.isDebugEnabled()){
log.debug("del user "+id);
}
}
}
在這個類中實現了IUserDAO接口的方法,並且繼承了HibernateDAOSupport類。這個類的作用是通過hibernate訪問、操作對象,進而實現對數據庫的操作。