打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Struts+Spring+Hibernate开发实例 复杂版--寒月清风
Struts+Spring+Hibernate开发实例 复杂版

介绍

本文并不想介绍StrutsSpringHibernate的原理系统架构等,本文地目的是通过一个较复杂地实例介绍如何整合StrutsSpringHibernate,网上现有的例子虽然也能达到目的,但功能都比较单一,复杂的例子时会有意想不到的麻烦。本文对读者假设已经具备了以上框架的基础知识。以及那些已经了解StrutsSpringHibernate的基本概念,但是还没有亲身在较复杂的项目中体验StrutsSpringHibernate的开发人员。

1 Struts

    虽然不打算过多介绍Struts的原理,但是大概介绍一下还是有必要的。Struts本身就是 MVC 在这里负责将用户数据传人业务层,以及 将业务层处理的结果返回给用户,此系统属于较简单WEB应用,采用了OpenSessionInView模式处理LazyLoad问题,这样我们可以在用户视图中使用 getset方法来方便地获取关联对象。为了处理庞大的ActionActionForm问题,在此我门准备使用DynaActionForm (DynaValidatorForm)DispatchAction以及 动态验证框架 来解决。及使用Tile来解决框架问题 。使用自定义标签处理分页和身份验证问题。

2 Spring

    Spring Framework最得以出名的是与Hibernate的无缝链接,虽然Spring Hibernate提供了90%以上的封装,使我们不必去关心Session 的建立,关闭,以及事务使我们能够专心的关注业务逻辑。但是一些特殊情况如 有时需要Query以及Criteria 对象,分页等,Spring不能给我们提供支持,总不能每次都在你的DAO上写个HibernateCallBackup()吧?Spring的作用不是把Hibernate再封装一层,而是让你接触不到HibernateAPI,而是帮助你管理好SessionTransaction

在这里解决方法是:首先 写一个IBase 的接口,和一个BaseDao的实现。在实现中仿照HibernateTemplate,将其功能一一实现,同时考虑到Spring 未能支持的地方,我们不得已只好自己来管理Session,因此加入public Session openSession()public Query getQuery(String sql)public Criteria getCriteria(Class clazz),以及分页的方法。 然后为每一个Entity 都建立继承于以上类的IEntity,与EntityDao。这里可以根据需求对Entity加入特殊的方法实现,如 StudentsDao.java 中加入类似用户身份验证等。以上就是数据访问层。接下来在Service层中通过对dao的引用完成业务逻辑方法。在下面的例子中我们分别为学生模块,教师模块,管理员模块构建Service层,StudentsServiceImplTeachersServiceImplAdminServiceImpl

 

3 Hibernate

 有了Spring的封装,我们要对Hibernate做的就是正确实现对象关系的映射。由于此处处于系统的最底层,准确无误的实现对象之间的关联关系映射将起着至关重要的作用。

 总之,理解了StrutsSpringHibernate地原理以及之间的关系之后,剩下的工作就如同在以Spring为核心的Struts为表现的框架中堆积木。

下图可以更好的帮助我们理解StrutsSpringHibernate之间的关系。


案例简述

设计思路主要源于 大学选修课,该系统可以方便处理学生在课程选报,学分查询,成绩查询,以及 成绩发布等。

系统以班级为核心,一门课程可以对应多个班级,一名教师也可以带不同的班级,学生可以选报不同课程所对应的班级,班级自身有目前人数,和最大人数,以及上课时间,上课地点的属性。

学生在选报班级之后,班级的人数会自动加一,直到等于最大人数时,其他学生将会有人数已满的错误提示。同理如果学生选择了同一课程的不同班级,也将收到错误提示。学生有密码,系别,学分,地址,电话等属性。

教师在系统中主要负责成绩发布,教师可以对其所带的班级的学生的成绩修改,系统会以成绩是否大于等于60来判断学生是否通过考试,如果通过会将该课程的学分累加到学生学分,同样如果教师二次修改了成绩,而且小于60,系统会在学生学分上扣掉该课程的分数。

课程在系统中具体体现为班级,自身带有学分属性。
< body="">

系有编号,名称的属性,同时可以作为联系教师,课程,学生的桥梁。

 

功能模块

l       身份验证模块: 根据用户名,密码,用户类别 转发用户到不同的模块。

l       学生模块: 查看课程,查看班级,选报课程,查看己选课程,成绩查询。

l       教师模块: 录入成绩

l       管理员模块:对学生,教师,课程,班级,系 增,删,查,改。

 

具体实践

代码下载
http://www.blogjava.net/Files/limq/StudentManger.rar
1  
对象关系映射:

首先,将库表映射为数据模型(SQL在源码中查看),转换后的数据模型如下图:


由此我们可以看出一下关联关系:

1 Students Contact(联系方式)一对一关系。

2 Students History(选课历史) 一对多关系

3 Students Classes 多对多关系。

4 Classes Classes_info 一对多关系。

5 Classes Teachers 多对一关系。

6 Classes Courses 多对一关系。

7 Course Department(系) 多对一关系。

8 Teachers Department 多对一关系。

9 Students Department 多对一关系。

 

Hibernate中将以上关系一一映射,如Students History 一对多关系

Students.cfg.xm.

 1 <set name="history"
 2                  table="history" 
 3                  cascade="all"
 4                  inverse="true"
 5                  lazy="true"  >
 6                 <key  column="student_id"/> 
 7             <one-to-many class="limq.hibernate.vo.History"
 8                                     />
 9             < span="">set>
10 

同样在History.cfg.xml中加入:

1  <many-to-one name="student"
2                   class="limq.hibernate.vo.Students"
3                   column="student_id"  >    
4      < span="">many-to-one>
5 

用过MyEclipse开发Hibernate的就知道,MyEclipse会帮助我们生成持久对象和抽象对象,我们要在 Students.java 中加入对History的引用

private Set history=new HashSet();

 

     public Set getHistory() {

        return history;

      }

 

    public void setHistory(Set history) {

        this.history = history;

}

同时,在AbstractHistory.java 中删除student_id 以及对应的getset 方法,History.java 中加入

private Students student;

public Students getStudent() {

        return student;

    }

  

 public void setStudent(Students student) {

        this.student = student;

    }

具体内容请查看 源代码。

2 DAO 数据访问层

首先,编写IBaseDaoBaseDao,其中IBaseDao代码如下:

 1 package limq.hibernate.dao;
 2 
 3 import java.util.Collection;
 4 import java.util.List;
 5 import net.sf.hibernate.Criteria;
 6 import net.sf.hibernate.Query;
 7 import net.sf.hibernate.Session;
 8 import limq.exception.DaoException;
 9 
10 public interface IBaseDao {
11     
12     public Session openSession();
13     
14     public  int getTotalCount( String hql) throws Exception;
15     

http://www.blogjava.net/limq/archive/2005/09/20/13565.aspx

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
面试Java实习生时的一些面试题
一篇SSH框架的应用介绍
Spring试题和答案
JAVA工程师简历模板
Spring 学习一(了解Spring)
精选程序员个人简历模板_JavaEE工程师简历模板
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服