本文是開發(fā)基于spring的web應(yīng)用的入門文章,前端采用Struts MVC框架,中間層采用spring,后臺采用Hibernate。
本文包含以下內(nèi)容:
·配置Hibernate和事務(wù)
·裝載Spring的applicationContext.xml文件
·建立業(yè)務(wù)層和DAO之間的依賴關(guān)系
·將Spring應(yīng)用到Struts中
簡介 這個例子是建立一個簡單的web應(yīng)用,叫MyUsers,完成用戶管理操作,包含簡單的數(shù)據(jù)庫增,刪,查,該即CRUD(新建,訪問,更新,刪除)操作。這是一個三層的web應(yīng)用,通過Action(Struts)訪問業(yè)務(wù)層,業(yè)務(wù)層訪問DAO。圖一簡要說明了該應(yīng)用的總體結(jié)構(gòu)。圖上的數(shù)字說明了流程順序-從web(UserAction)到中間層(UserManager),再到數(shù)據(jù)訪問層(UserDAO),然后將結(jié)果返回。
Spring層的真正強(qiáng)大在于它的聲明型事務(wù)處理,幫定和對持久層支持(例如Hiberate和iBATIS)
以下下是完成這個例子的步驟:
1. 安裝Eclipse插件
2. 數(shù)據(jù)庫建表
3. 配置Hibernate和Spring
4. 建立Hibernate DAO接口的實現(xiàn)類
5. 運(yùn)行測試類,測試DAO的CRUD操作
6. 創(chuàng)建一個處理類,聲明事務(wù)
7. 創(chuàng)建web層的Action和model
8. 運(yùn)行Action的測試類測試CRUD操作
9. 創(chuàng)建jsp文件通過瀏覽器進(jìn)行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,
數(shù)據(jù)庫建表create table app_user(id number not null primary,firstname vchar(32),lastname vchar(32)); |
新建項目 新建一個web project,新建后的目錄結(jié)構(gòu)同時包含了新建文件夾page用于放jsp文件,和源文件夾test用于放junit測試文件。同時將用到的包,包括struts,hibernate,spring都導(dǎo)入到lib目錄下。
創(chuàng)建持久層O/R mapping
1. 在src/com.jandar.model下用hibernate插件從數(shù)據(jù)庫導(dǎo)出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對象對應(yīng)于數(shù)據(jù)庫中的app_user表
注:在eclipse下自動生成的對象文件不完全相同,相同的是每個對象文件必須實現(xiàn)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; } } |
創(chuàng)建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); } } } |
在這個類中實現(xiàn)了IUserDAO接口的方法,并且繼承了HibernateDAOSupport類。這個類的作用是通過hibernate訪問、操作對象,進(jìn)而實現(xiàn)對數(shù)據(jù)庫的操作。