基于JAVA EE 《中兴软件供应链系统》的框架设计和项目管理文献综述
2020-05-22 20:57:07
文 献 综 述
Struts2是基于Java EE Web应用的MVC设计模式的应用框架。使用Struts2运用MVC设计模型来开发Web应用的时间。在服务器启动后,Struts2根据web.xml加载ActionServlet读取struts-config.xml文件内容到内存。
Spring是为了解决企业应用开发的复杂性而创建的。它可以基于JavaBean来完成以前只可能由EJB完成的事情。Spring的用途不仅用于服务器端的开发,从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在JavaServlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以应用在EJB的Java应用中。
以上简单介绍了Struts2,Spring,Hibernate它们各自的实现方式,然而将它们整合在一起,又是如何实现业务逻辑的呢?执行效果又如何呢?可想而知,整合后的框架会更强大,执行效率会更快。基于分开的三大框架,集成后的框架便是质的飞跃!
在实现业务逻辑时,Hibernate主要执行以下操作:首先通Configuration().configure()读取并解析hibernate.cfg.xml配置文件,再由hibernate.cfg.xml中的lt;mapping resource=”com/xx/xx.xml”gt;读取并解析映射信息,然后通过config buildSessionFactory()代码以创建SessionFactory,再执行sessionFactory.openSession()打开Session,接下来执行session beginTransaction()创建Transaction事务,再通过persistent operate 实现持久化操作,最后通过session.getTransaction().commit()提交事务,然后关闭Session,关闭sesstionFactory。
在Hibernate实现了它所应负责的业务逻辑的同时还要处理一个很重要的问题:加载和缓存问题。那么Hibernate如何完成这些要求的呢? Hibernate通过如下操作延迟加载:在Hibernate2中通过操作实体对象和集合延迟加载;Hibernate3中提供了属性的延迟加载功能。当Hibernate在查询数据的时候,数据并没有存在于内存中,当程序真正对数据进行操作时,对象才存在于内存中,这样实现了延迟加载,它节省了服务器的内存开销,从而提高了服务器的性能。最后讨论下Hibernate的缓存机制。首先介绍一些缓存的概念:内部缓存存在Hibernate中又叫一级缓存,属于应用事务级别缓存;应用缓存及分布式缓存称为二级缓存,其中分布式缓存是指:数据不会被第三方修改、数据大小在可接受范围、数据更新频率低、同一数据被频繁使用的缓存;最后还有三级缓存。接下来具体介绍一下各级缓存:一级缓存是session级的缓存也叫事务级的缓存,只缓存实体,生命周期和session一致,不能对其进行管理,不用显式地调用;二级缓存是sessionFactory缓存也叫做进程级缓存,使用第三方插件实现,也是只缓存实体,生命周期和sessionFactory一致,可以进行管理。其中用到了第三方插件,我们用EHCache可以先在hibernate.cfg.xml文件中加入lt;property namehibernate.cache.user_second_level
Cache”gt;truelt;/propertygt;,同时在映射中也要显式地调用lt;cache usage=”read-only”/gt;在二级缓存中,如果关联的表发生了修改,那么查询缓存的生命周期也结束了。如果要再次查询该表,就要在程序中手动启用查询缓存:query.setCacheable(true) 。在实现系统的业务逻辑时,Struts主要操作是:web应用启动时会加载初始化ActionServlet,ActionServlet,从struts-config.xml文件中读取配置信息,它们存放到各种配置对象。当ActionServlet接收到一个客户请求时,将执行如下流程:首先检索和用户请求匹配的ActionMapping实例,如果不存在,就返回请求路径无效信息,如果ActionForm实例不存在,就创建一个ActionForm对象,把客户提交的表单数据保存到ActionForm对象中,再根据配置信息决定是否需要表单验证,如果需要验证,就调用ActionForm的validate()方法。如果ActionForm的validate()方法返回null或返回一个不包含ActionMessage的ActuibErrors对象,就表示表单验证成功。接下来ActionServlet根据ActionMapping所包含的映射信息决定将请求转发给哪个Action,如果相应的 Action实例不存在,就先创建这个实例,然后调用Action的execute()方法。然后Action的execute()方法返回一个ActionForward对象,ActionServlet在把客户请求转发给 ActionForward对象指向的JSP组件。最后ActionForward对象指向JSP组件生成动态网页,返回给客户 。而Spring主要执行的操作是:Spring Mvc将所有的请求都提交给DispatcherServlet,它会委托应用系统的其他模块负责对请求进行真正的处理工作。然后通过DispatcherServlet查询一个或多个HandlerMapping找到处理请求的Controller,再由DispatcherServlet将请求提交到目标Controller,待Controller进行业务逻辑处理后,会返回一个ModelAndView,再由Dispathcher查询一个或多个ViewResolver视图解析器,找到ModelAndView对象指的视图对象,最后视图对象负责渲染返回给客户端。这样从表面上看Struts、Spring、Hibernate在系统中各司其责,但实质上它们内在联系非常之多,它们是一个整体,如果离开了其中任意一个分支,那么系统的业务逻辑就不会实现的那么自然,也不会最大的发挥SSH集成框架的优越其他框架的功能。
整个SSH集成框架贯穿于系统的表示层、业务逻辑层、数据持久层和域模块层,帮助开发人员在短期内搭建结构清晰、可复用性好、维护方便的Web应用程序。SSH集成框架业务逻辑实现方法可以总的概括为:通过JSP页面实现交互界面,负责传送请求(Request)和接收响应(Response),然后Struts根据配置文件(struts-config.xml)将ActionServlet接收到的Request委派给相应的Action处理。管理服务组件的Spring IoC容器负责向Action提供业务模型(Model)组件和该组件的协作对象数据处理(DAO)组件完成业务逻辑,并提供事务处理、缓冲池等容器组件以提升系统性能和保证数据的完整性。最后依赖Hibernate的对象化映射和数据库交互,处理DAO组件请求的数据,并返回处理结果。
通过上面的论述,我们对业务逻辑和SSH集成框架有了初步的了解,并学习了SSH实现业务逻辑的方法:使用Struts作为系统的整体基础架构,负责MVC的分离,在Struts框架的模型部分,控制业务跳转,利用Hibernate框架对持久层提供支持,Spring做管理,管理struts和hibernate。。具体做法是:用面向对象的分析方法根据需求提出一些模型,将这些模型实现为基本的Java对象,然后编写基本的DAO(Data Access Objects)接口,并给出Hibernate的DAO实现,采用Hibernate架构实现的DAO类来实现Java类与数据库之间的转换和访问,最后由Spring做管理,管理struts和hibernate。