struts2、spring4、hibernate4(ssh)整合案例

    xiaoxiao2021-04-17  35

    框架介绍

    SSH是 struts+spring+hibernate的一个集成框架,是目前比较流行的一种Web应用程序开源框架。 集成SSH框架的系统从职责上分为四层:表示层、业务逻辑层、数据持久层和域模块层,以帮助开发人员在短期内搭建结构清晰、可复用性好、维护方便的Web应用程序。其中使用Struts作为系统的整体基础架构,负责MVC的分离,在Struts框架的模型部分,控制业务跳转,利用Hibernate框架对持久层提供支持,Spring做管理,管理struts和hibernate。具体做法是:用面向对象的分析方法根据需求提出一些模型,将这些模型实现为基本的Java对象,然后编写基本的DAO(Data Access Objects)接口,并给出Hibernate的DAO实现,采用Hibernate架构实现的DAO类来实现Java类与数据库之间的转换和访问,最后由Spring做管理,管理struts和hibernate。

    业务流程

    系统的基本业务流程是: 在表示层中,首先通过JSP页面实现交互界面,负责接收请求(Request)和传送响应(Response),然后Struts根据配置文件(struts-config.xml)将ActionServlet接收到的Request委派给相应的Action处理。在业务层中,管理服务组件的Spring IoC容器负责向Action提供业务模型(Model)组件和该组件的协作对象数据处理(DAO)组件完成业务逻辑,并提供事务处理、缓冲池等容器组件以提升系统性能和保证数据的完整性。而在持久层中,则依赖于Hibernate的对象化映射和数据库交互,处理DAO组件请求的数据,并返回处理结果。 采用上述开发模型,不仅实现了视图、控制器与模型的彻底分离,而且还实现了业务逻辑层与持久层的分离。这样无论前端如何变化,模型层只需很少的改动,并且数据库的变化也不会对前端有所影响,大大提高了系统的可复用性。而且由于不同层之间耦合度小,有利于团队成员并行工作,大大提高了开发效率。

    框架结构

    Struts1 Struts对Model,View和Controller都提供了对应的组件。 ActionServlet,这个类是Struts1的核心控制器,负责拦截来自用户的请求。 Action,这个类通常由用户提供,该控制器负责接收来自ActionServlet的请求,并根据该请求调用模型的业务逻辑方法处理请求,并将处理结果返回给JSP页面显示。 Model部分: 由ActionForm和JavaBean组成,其中ActionForm用于将用户的请求参数封装成ActionForm对象,该对象被ActionServlet转发给Action,Action根据ActionForm里面的请求参数处理用户的请求。 JavaBean则封装了底层的业务逻辑,包括数据库访问等。 View部分: 该部分采用JSP(或HTML、PHP……)实现。 Struts提供了丰富的标签库,通过标签库可以减少脚本的使用,自定义的标签库可以实现与Model的有效交互,并增加了现实功能。对应上图的JSP部分。 Controller组件: Controller组件有两个部分组成——系统核心控制器,业务逻辑控制器。 系统核心控制器,对应上边的ActionServlet。该控制器继承了HttpServlet类,因此可以配置成标注的Servlet。该控制器负责拦截所有的HTTP请求,然后根据用户请求决定是否要转给业务逻辑控制器。 业务逻辑控制器,负责处理用户请求,本身不具备处理能力,而是调用Model来完成处理。对应Action部分。 Spring Spring是一个开源框架,它由Rod Johnson创建。它是为了解决企业应用开发的复杂性而创建的。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。 目的:解决企业应用开发的复杂性 功能:使用基本的JavaBean代替EJB,并提供了更多的企业应用功能 范围:任何Java应用 简单来说,Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。 轻量——从大小与开销两方面而言Spring都是轻量的。完整的Spring框架可以在一个大小只有1MB多的JAR文件里发布。并且Spring所需的处理开销也是微不足道的。此外,Spring是非侵入式的:典型地,Spring应用中的对象不依赖于Spring的特定类。 控制反转——Spring通过一种称作控制反转(IoC)的技术促进了松耦合。当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象。你可以认为IoC与JNDI相反——不是对象从容器中查找依赖,而是容器在对象初始化时不等对象请求就主动将依赖传递给它。 面向切面——Spring提供了面向切面编程的丰富支持,允许通过分离应用的业务逻辑与系统级服务(例如审计(auditing)和事务(transaction)管理)进行内聚性的开发。应用对象只实现它们应该做的——完成业务逻辑——仅此而已。它们并不负责(甚至是意识)其它的系统级关注点,例如日志或事务支持。 容器——Spring包含并管理应用对象的配置和生命周期,在这个意义上它是一种容器,你可以配置你的每个bean如何被创建——基于一个可配置原型(prototype),你的bean可以创建一个单独的实例或者每次需要时都生成一个新的实例——以及它们是如何相互关联的。然而,Spring不应该被混同于传统的重量级的EJB容器,它们经常是庞大与笨重的,难以使用。 框架——Spring可以将简单的组件配置、组合成为复杂的应用。在Spring中,应用对象被声明式地组合,典型地是在一个XML文件里。Spring也提供了很多基础功能(事务管理、持久化框架集成等等),将应用逻辑的开发留给了你。 所有Spring的这些特征使你能够编写更干净、更可管理、并且更易于测试的代码。它们也为Spring中的各种模块提供了基础支持。 Hibernate Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何场合使用JDBC,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。 Hibernate的核心接口一共有5个,分别为:Session、SessionFactory、Transaction、Query和Configuration。这5个核心接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制。下面对这五个核心接口分别加以介绍。 ·Session接口:Session接口负责执行被持久化对象的CRUD操作(CRUD的任务是完成与数据库的交流,包含了很多常见的SQL语句。)。但需要注意的是Session对象是非线程安全的。同时,Hibernate的session不同于JSP应用中的HttpSession。这里当使用session这个术语时,其实指的是Hibernate中的session,而以后会将HttpSession对象称为用户session。 ·SessionFactory接口:SessionFactory接口负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。这里用到了工厂模式。需要注意的是SessionFactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个SessionFactory就够,当需要操作多个数据库时,可以为每个数据库指定一个SessionFactory。 ·Configuration接口:Configuration接口负责配置并启动Hibernate,创建SessionFactory对象。在Hibernate的启动的过程中,Configuration类的实例首先定位映射文档位置、读取配置,然后创建SessionFactory对象。 ·Transaction接口:Transaction接口负责事务相关的操作。它是可选的,开发人员也可以设计编写自己的底层事务处理代码。 ·Query和Criteria接口:Query和Criteria接口负责执行各种数据库查询。它可以使用HQL语言或SQL语句两种表达方式。 (以上内容摘自百度百科)

    案例 步骤一:创建javaweb项目 步骤二:导入jar包(包括ssh包和数据库连接驱动包) antlr-2.7.7.jar asm-3.3.jar asm-commons-3.3.jar asm-tree-3.3.jar c3p0-0.9.2.1.jar commons-fileupload-1.3.2.jar commons-io-2.2.jar commons-lang3-3.2.jar commons-logging-1.1.3.jar dom4j-1.6.1.jar freemarker-2.3.22.jar hibernate-c3p0-4.2.21.Final.jar hibernate-commons-annotations-4.0.2.Final.jar hibernate-core-4.2.21.Final.jar hibernate-jpa-2.0-api-1.0.1.Final.jar javassist-3.11.0.GA.jar javassist-3.18.1-GA.jar jboss-logging-3.1.0.GA.jar jboss-transaction-api_1.1_spec-1.0.1.Final.jar log4j-api-2.3.jar log4j-core-2.3.jar mchange-commons-java-0.2.3.4.jar mysql-connector-java-5.1.41-bin.jar ognl-3.0.19.jar spring-aop-4.2.0.RELEASE.jar spring-aspects-4.2.0.RELEASE.jar spring-beans-4.2.0.RELEASE.jar spring-context-4.2.0.RELEASE.jar spring-context-support-4.2.0.RELEASE.jar spring-core-4.2.0.RELEASE.jar spring-expression-4.2.0.RELEASE.jar spring-instrument-4.2.0.RELEASE.jar spring-instrument-tomcat-4.2.0.RELEASE.jar spring-jdbc-4.2.0.RELEASE.jar spring-jms-4.2.0.RELEASE.jar spring-messaging-4.2.0.RELEASE.jar spring-orm-4.2.0.RELEASE.jar spring-oxm-4.2.0.RELEASE.jar spring-test-4.2.0.RELEASE.jar spring-tx-4.2.0.RELEASE.jar spring-web-4.2.0.RELEASE.jar spring-webmvc-4.2.0.RELEASE.jar spring-webmvc-portlet-4.2.0.RELEASE.jar spring-websocket-4.2.0.RELEASE.jar struts2-core-2.3.32.jar xwork-core-2.3.32.jar 步骤三:创建核心配置文件 web.xml

    <?xml version="1.0" encoding="UTF-8"?> <web-app id="WebApp_9" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"> <display-name>Struts Blank</display-name> <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- spring的监听器配置开始 --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:beans.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> </web-app>

    步骤四:创建包类列表(这样有利于有一个清晰的思路)

    步骤五:创建实体类BookCard.java以及映射文件entity.hbm.xml

    package com.sun.entity; import java.math.BigDecimal; import java.util.Date; /* * 跟数据库一致,作为一个java对象 * 1个对象代表的是数据库中的一行记录 * 1个属性代表的是表中的一个字段 */ public class BookCard { private int cid; private String name; private String sex; private Date cardDate; private BigDecimal deposit; public int getCid() { return cid; } public void setCid(int cid) { this.cid = cid; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public Date getCardDate() { return cardDate; } public void setCardDate(Date cardDate) { this.cardDate = cardDate; } public BigDecimal getDeposit() { return deposit; } public void setDeposit(BigDecimal deposit) { this.deposit = deposit; } } <?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.sun.entity"> <class name="BookCard" table="bookcard"> <!-- 卡号 --> <id name="cid"> <generator class="native" /> </id> <!-- 姓名 --> <property name="name" column="name"/> <!-- 性别 --> <property name="sex" column="sex"/> <!-- 办卡日期 --> <property name="cardDate" column="cardDate" /> <!-- 押金 --> <property name="deposit" column="deposit" /> </class> </hibernate-mapping>

    步骤六:创建IndexAction类以及struts.xml文件

    package com.sun.action; import java.text.DecimalFormat; import java.util.List; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import com.opensymphony.xwork2.Action; import com.opensymphony.xwork2.ActionContext; import com.opensymphony.xwork2.ActionSupport; import com.sun.entity.BookCard; import com.sun.service.IndexService; public class IndexAction extends ActionSupport { //声明service,但不给它创建具体的实现类实例 private IndexService is; //添加set()方法 public void setIs(IndexService is) { this.is = is; } //编写execute()方法 public String execute(){ ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml"); is = (IndexService) context.getBean("indexService"); //获取IndexService实例,调用getAllBookCard()方法 //将结果保存到List集合里 System.out.println(is); List<BookCard> myBookCardsList = is.getAllBookCard(); //将查询出来的机构集打印到控制台 System.out.println("结果集:"+myBookCardsList.size()); //获取上下文对象 ActionContext actionContext = ActionContext.getContext(); //将myBookCardList集合添加到上下文对象里 actionContext.put("myBookCardsList", myBookCardsList); //返回字符串 return Action.SUCCESS; } //金额格式转换 public String formatDouble(double e){ DecimalFormat decimalFormat = new DecimalFormat("\u00A4##.0"); return decimalFormat.format(e); } } <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd"> <struts> <package name="default" namespace="/" extends="struts-default"> <action name="login" class="com.sun.action.IndexAction"> <result>/index.jsp</result> </action> </package> </struts>

    步骤七:创建IndexService接口及实现类IndexServiceImpl

    package com.sun.service; import java.util.List; import com.sun.entity.BookCard; public interface IndexService { public List<BookCard> getAllBookCard(); } package com.sun.service; import java.util.List; import com.sun.dao.IndexDao; import com.sun.entity.BookCard; public class IndexServiceImpl implements IndexService{ //dao实例使用注入方式 private IndexDao indexDao; //set public void setIndexDao(IndexDao indexDao) { this.indexDao = indexDao; } @Override public List<BookCard> getAllBookCard() { //本类应该编写业务逻辑代码 //但本类没有业务逻辑,就不用写 //访问数据库的代码,不会出现在service这一层 //应给交给dao来操作数据库 List<BookCard> myBookCardList = indexDao.getAllBookCard(); //进行其他的业务逻辑操作,比如增加多一个选项,是否过期 //本例不需要 return myBookCardList; } }

    步骤八:编写IndexDao接口及IndexDaoImpl实现类

    package com.sun.dao; import java.util.List; import com.sun.entity.BookCard; public interface IndexDao { public List<BookCard> getAllBookCard(); } package com.sun.dao; import java.util.List; import org.hibernate.Query; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.Configuration; import com.sun.entity.BookCard; public class IndexDaoImpl implements IndexDao{ //在SSH的设计理念:要使用某个实例,那么就定义声明一个对象,然后给他添加set方法(用于spring注入进来) //实现不要关注这个实例来自于哪里,以及怎么创建,或者他是谁 private SessionFactory sessionFactory; public void setSessionFactory(SessionFactory sessionFactory){ this.sessionFactory = sessionFactory; } @Override public List<BookCard> getAllBookCard() { //sessionFactory这个实例可以按照常规的方法创建 //也可以交给spring托管 // Configuration cfg = new Configuration().configure(); // sessionFactory = cfg.buildSessionFactory(); //获取session Session session = sessionFactory.openSession(); //后面当时用JPA的时候,EntityManager类似于Session Query query = session.createQuery("from BookCard"); //将所有的数据查询出来并放到List集合里 List<BookCard> list = query.list(); return list; } }

    步骤九:编写spring注入文件beans.xml

    <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd" default-autowire="byName"> <bean id="myDao" class="com.sun.dao.IndexDaoImpl" scope="prototype"> <property name="sessionFactory" ref="mysessionFactory"/> </bean> <bean id="indexService" class="com.sun.service.IndexServiceImpl"> <property name="indexDao" ref="myDao"/> </bean> <bean id="indexAction" class="com.sun.action.IndexAction"> <property name="is" ref="indexService"/> </bean> <!-- mysql hibernate配置 --> <!-- 注入sessionFactory --> <bean id="mysessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> <!-- 注入连接池,包含了数据库名,密码等等信息 --> <property name="dataSource" ref="myDataSource2"></property> <!-- 配置Hibernate的其他属性 --> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop> <prop key="hibernate.connection.autocommit">false</prop> <!-- 开机自动生成表 --> <prop key="hibernate.hbm2ddl.auto">update</prop> </props> </property> <property name="mappingResources"> <list> <value>com/sun/entity/entity.hbm.xml</value> </list> </property> </bean> <bean id="myDataSource2" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <property name="driverClass" value="com.mysql.jdbc.Driver"/> <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/test"/> <property name="user" value="root"/> <property name="password" value="123456"/> </bean> </beans>

    数据库表

    执行结果

    转载请注明原文地址: https://ju.6miu.com/read-673502.html

    最新回复(0)