本文是開發基于spring的
Web應用的入門文章,前端采用
Struts M
VC框架,中間層采用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://spring
Framework.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"> ?。糹d column="ID" name="id" type="integer" ?。?br /> ?。糶enerator class="assigned" />
</id>
?。紁roperty column="LASTNAME" length="10" name="lastname" not-null="false" type="string" />
?。紁roperty 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; } } |