2025-02-10

本文是開發基於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插件https://www.binamics.com/hibernatesync

   2. Spring插件https://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”
   “https://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訪問、操作對象,進而實現對數據庫的操作。

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *