Struts2+Spring+Hibernate 三大框架的合并集成

这次来看看Struts2+Spring+Hibernate三大框架的整合应用,主要是SpringHibernate框架的整合,因为前边已经将Strtus2+Spring整合过了基本一样。

   首先看一下分工吧:

  Struts2做的MVC的流程框架,主要完成从客户端访问到选择action的过程,其中过滤器起到了Controller的作用,action属于model,而jsp则是view页面的展示。

  Spring主要利用Ioc的特长来管理各种对象:action,service,dao,数据访问源,Hibernate的核心对象SessionFactory等,还有就是声明式事务的管理等。

  而Hibernate框架主要是实体层和数据库中表的映射,以及封装JDBC代码,提供相应的方法,供我们选择。这样从前台页面一直到后台数据库,都有了框架帮我们维护,使我们的开发变得简单快捷,效率大大提高。当然了,前提是我们对这些框架能够灵活的运用。

  再者,就是需要三大框架的导入的对应jar包,这里不再列出。以及对应的配置文件,这里需要说明一下,由于Hibernate框架的核心对象SessionFactory交给了Spring框架进行维护,这里就不需要hibernate.cfg.xml配置文件了,我们将这些信息写到Spring核心配置文件中即可。

   好,看一下各个配置文件的编写吧!

  1web.xml文件的几个重点项:

<!-- 用于指定Spring的配置文件路径 -->  
<context-param>  
    <param-name>contextConfigLocation</param-name>  
    <param-value>classpath:applicationContext.xml</param-value>  
</context-param>  
  
<!-- 服务器启动时,通过监听器初始化Spring的配置环境   
    监听器,默认加载文件是:/WEB-INF/applicationContext.xml  
-->  
<listener>  
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
</listener>  
  
  
<!-- OpenSessionInViewFilter过滤器需要配置在Struts2框架过滤器前面,否则不起作用。 -->  
<filter>  
    <filter-name>OpenSessionInViewFilter</filter-name>  
    <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>  
</filter>  
<filter-mapping>  
    <filter-name>OpenSessionInViewFilter</filter-name>  
    <url-pattern>/*</url-pattern>  
</filter-mapping>  
  
<!-- 配置框架的核心调度器 -->  
<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>  

  2Struts2核心配置文件的编写:

<package name="example" namespace="/user" extends="struts-default">  
       <action name="login" class="loginAction" method="login">  
           <result name="success" type="dispatcher">/success.jsp</result>  
           <result name="login" type="redirect">/login.jsp</result>  
       </action>  
   </package>  

  3Spring核心配置文件的编写:

<beans xmlns="http://www.springframework.org/schema/beans"  
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
        xmlns:aop="http://www.springframework.org/schema/aop"  
        xmlns:tx="http://www.springframework.org/schema/tx"  
        xsi:schemaLocation="  
            http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd  
            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd  
            http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"  
            default-autowire="byName">  
              
    <!-- 启用AOP功能 -->        
    <aop:aspectj-autoproxy></aop:aspectj-autoproxy>       
    <!-- action,service和dao层配置,这里使用了默认装配功能 -->  
    <bean id="loginAction" class="com.ljh.egov.action.LoginAction" scope="prototype"></bean>  
  
    <bean id="userService" class="com.ljh.egov.service.UserService" ></bean>  
      
    <bean id="userDao" class="com.ljh.egov.dao.UserDao">  
        <property name="sessionFactory" ref="sessionFactory"></property>  
    </bean>  
  
    <!--加载数据库的配置文件  -->  
    <bean class="org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer">  
        <property name="locations">  
            <list>  
                <value>classpath:db.properties</value>  
            </list>  
        </property>  
    </bean>  
      
    <!-- c3p0数据源的配置,这里也可以设置连接池的大小等等 -->  
    <bean id="c3p0" class="com.mchange.v2.c3p0.ComboPooledDataSource">  
        <property name="user" value="${username}"></property>  
        <property name="password" value="${password}"></property>  
        <property name="jdbcUrl" value="${url}"></property>  
        <property name="driverClass" value="${driverClass}"></property>   
    </bean>  
  
    <!-- sessionFactory的管理,里边通过各种标签进行管理 -->  
    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean" >  
        <property name="dataSource" ref="c3p0"></property>  
        <property name="hibernateProperties">  
            <props>  
                <!-- 打印sql语句 -->  
                <prop key="hibernate.show_sql">true</prop>  
                <!-- 格式化sql语句 -->  
                <prop key="hibernate.format_sql">true</prop>  
                <!-- 当构建SessionFactory对象时,通过映射文件自动创建表 -->  
                <prop key="hibernate.hbm2ddl.auto">update</prop>  
                <!-- 数据库方言 -->  
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>  
            </props>  
        </property>  
        <!-- 映射文件的包路径 -->  
        <property name="mappingDirectoryLocations">  
            <list>  
                <value>classpath:com/ljh/egov/bean</value>  
            </list>  
        </property>  
    </bean>  
  
    <!-- 配置功能扩展对象 - 事务管理 -->  
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
        <property name="dataSource" ref="c3p0"></property>  
    </bean>  
      
    <!-- 声明事务管理AOP功能 -->  
    <aop:config>  
        <aop:advisor advice-ref="transactionAdvice" pointcut="execution(* com.ljh.egov..service.*.*(..))"/>     
    </aop:config>   
      
    <tx:advice id="transactionAdvice" transaction-manager="transactionManager">  
        <tx:attributes>  
            <tx:method name="save*" propagation="REQUIRED" isolation="DEFAULT" rollback-for="java.lang.Exception"/>  
            <tx:method name="delete*" propagation="REQUIRED" isolation="DEFAULT" rollback-for="java.lang.Exception"/>  
            <tx:method name="update*" propagation="REQUIRED" isolation="DEFAULT" rollback-for="java.lang.Exception"/>  
            <tx:method name="select*" read-only="true"/>  
        </tx:attributes>  
    </tx:advice>  
  
</beans>  

  4,在Dao层的编写中,这里简单说一下如何获得session对象,去进行相关方法的调用,完成我们的数据操作功能。Dao层首先需要实现我们的HibernateDaoSupport,以便使用此父类中的getHibernateTemplate方法,进行相关方法的调用,先看一个查询方法的实现:

   //参数需要final修饰        public User select(final User user) throws Exception {   
    //HibernateTemplate模板类不能直接支持Query,Criteria接口操作,所以可以通过回调函数传递Session对象,来使用这两个接口。    
    //当调用execute方法时,execute方法会回调参数对象的重写方法(doInHibernate).  
    //这里的利用匿名内部类,充当了一个回调函数,就是为了使用类中的Session对象  
    return (User)this.getHibernateTemplate().execute(new HibernateCallback(){  
        //称之为回调函数,一般由框架负责调用执行。  
        public Object doInHibernate(Session session) throws HibernateException,SQLException {  
              
         //在匿名内部类中引用方法的局部变量,必须是final修饰的。                  
              
            Query query = session.createQuery("from User u where u.usercode=? and u.userpswd=?");                 
              
            query.setParameter(0, user.getUsercode());  
            query.setParameter(1, user.getUserpswd());  
  
            return query.uniqueResult();  
        }             
    });  
}  

对于其它配置文件,这里不再给出,和单自使用框架差不多!当然对于这些配置文件,我们也可以根据实际业务进行划分,是每一个配置文件的功能单一,容量不至于过大,方便我们的管理。

最后简单说一下,三大框架应用中优化的考虑问题吧!

  Struts2

    1,发布时需要关闭开发模式(DevMode

    2,不使用用不到的拦截器,拦截器等各种组件越多,性能越低,奔着一个达到目标使用最少的原则,进行相关开发。

    3,过滤器的过滤规则尽量不要使用/*,这里我们开发可以制定规则,将过滤器的过滤范围降低到最小,方便框架的快速过滤!

 

  Spring:

    1,尽量不要采用自动装配,使用手动装配指明方向,框架能够更快的寻找到相关的类。

    2,尽量使用延迟加载功能,这样可以减少和数据库的通信,提高性能。

  Hibernate:

    1,所有框架使用较新的版本,可以提供更好的性能支持,毕竟什么东西都是向着更好的方向发展。但是也不要一味的追求最新,如果有bug或什么情况还是不好的,奔着一个在有把握的基础上寻求最新的原则。

    2,使用合理的缓存策略,主要是二级缓存和查询缓存的选择使用,根据实际情况,合理使用。

    3,尽量使用延迟加载功能。

    4,推荐使用uuid的主键生成策略,移植性好,支持大数据量。

    5,推荐使用乐观锁代替悲观锁。

    总而言之,合理使用框架中的一些功能,考虑全面,来提高使用框架的性能。

    当然,这里只是简单的框架搭建,还有很多功能,没有加入,需要我们根据实际的情况,不断的完善配置文件,使其的功能越来越强大,使我们的项目开发完全融入到框架中开发,那样我们才会得心应手。总而言之,需要我们多用,多观察,多总结,多反思……

原文地址:https://www.cnblogs.com/huangcongcong/p/4746556.html