Spring 2.5.6 + Struts 2.1.6 + Hibernate 3.3.1 GA + Jboss 4.2.2 整合

首先就着手解决包的问题

从网上东拼西凑的文章中,然后一个一个包的测试,首先我先在Tomcat下测试的。所以其中多了几个tomcat需要的commons包。

首先贴一下Web.xml文件的内容吧。

<? xml version="1.0" encoding="UTF-8" ?>
< web-app  version ="2.5"  xmlns ="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation
="http://java.sun.com/xml/ns/javaee 
    http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
>

    
< session-config >
        
< session-timeout > 30 </ session-timeout >
    
</ session-config >

    
<!--  log4j配置文件  -->
    
< context-param >
        
< param-name > log4jConfigLocation </ param-name >
        
< param-value > /WEB-INF/classes/log4j.properties </ param-value >
    
</ context-param >

    
<!--  Spring配置文件位置  -->
    
< context-param >
        
< param-name > contextConfigLocation </ param-name >
        
< param-value > /WEB-INF/classes/applicationContext.xml </ param-value >
    
</ context-param >

    
<!--  加载Spring配置文件  -->
    
< listener >
        
< listener-class > org.springframework.web.context.ContextLoaderListener </ listener-class >
    
</ listener >

    
<!-- 解决Hibernate延迟加载出现的问题,需要放到struts2过滤器之前 -->
    
< filter >
        
< filter-name > lazyLoadingFilter </ filter-name >
        
< filter-class >
            org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
</ filter-class >
    
</ filter >

    
<!--  Struts过滤器  -->
    
< filter >
        
< filter-name > struts2 </ filter-name >
        
< filter-class > org.apache.struts2.dispatcher.FilterDispatcher </ filter-class >
    
</ filter >

    
<!-- 解决Hibernate延迟加载出现的问题,仍需要放到struts2过滤器mapping之前 -->
    
< filter-mapping >
        
< filter-name > lazyLoadingFilter </ filter-name >
        
< url-pattern > *.action </ url-pattern >
    
</ filter-mapping >

    
< filter-mapping >
        
< filter-name > struts2 </ filter-name >
        
< url-pattern > /* </ url-pattern >
        
< dispatcher > REQUEST </ dispatcher >
        
< dispatcher > FORWARD </ dispatcher >
    
</ filter-mapping >

    
< filter >
        
< filter-name > EncodeFilter </ filter-name >
        
< filter-class > org.springframework.web.filter.CharacterEncodingFilter </ filter-class >
        
< init-param >
            
< param-name > encoding </ param-name >
            
< param-value > UTF-8 </ param-value >
        
</ init-param >
    
</ filter >
    
< filter-mapping >
        
< filter-name > EncodeFilter </ filter-name >
        
< url-pattern > /* </ url-pattern >
    
</ filter-mapping >

    
< welcome-file-list >
        
< welcome-file > index.jsp </ welcome-file >
    
</ welcome-file-list >
</ web-app >

 

然后再贴一下applicationContext.xml文件的内容。毕竟是spring配置,最核心的东西,把所有其他框架整合到一起的枢纽。

<? xml version="1.0" encoding="UTF-8"  ?>
< beans  xmlns ="http://www.springframework.org/schema/beans"
    xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance"  xmlns:p ="http://www.springframework.org/schema/p"
    xmlns:aop
="http://www.springframework.org/schema/aop"  xmlns:tx ="http://www.springframework.org/schema/tx"
    xmlns:context
="http://www.springframework.org/schema/context"
    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   
           http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd"
>
    
< description > Spring公共配置文件 </ description >

    
<!--  启用注解  -->
    
< context:annotation-config  />
    
<!--  使用annotation 自动注册bean,并保证@Required,@Autowired的属性被注入  -->
    
< context:component-scan  base-package ="com.gts.cns"   />

    
<!--  定义数据源的Bean ,提供给Hibernate的sessionFactory -->
    
< bean  id ="dataSource"  class ="org.springframework.jndi.JndiObjectFactoryBean" >
        
< property  name ="jndiName"  value ="java:/MySqlDS"   />
    
</ bean >

    
<!--      定义数据源的Bean ,提供给Hibernate的sessionFactory -->
<!--         <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> -->
<!--             <property name="driverClassName" value="com.mysql.jdbc.Driver"> -->
<!--             </property> -->
<!--             <property name="url" value="jdbc:mysql://localhost:3306/TPig"> -->
<!--             </property> -->
<!--             <property name="username" value="root"></property> -->
<!--             <property name="password" value="admin"></property> -->
<!--         </bean> -->

    
<!--  定义Hibernate的sessionFactory,通过该Bean,可以获得Hibernate的Session -->
    
< bean  id ="sessionFactory"
        class
="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean" >
        
< property  name ="dataSource" >
            
< ref  bean ="dataSource"   />
        
</ property >

        
<!--  自动扫描Class的hibernate映射文件  -->
        
< property  name ="packagesToScan" >
            
< list >
                
<!-- 若写成model.* 则映射不到,还没有来得及看源代码  -->
                
< value > * </ value >
            
</ list >
        
</ property >

        
< property  name ="hibernateProperties" >
            
< props >
                
< prop  key ="hibernate.dialect" > org.hibernate.dialect.MySQLDialect </ prop >
                
< prop  key ="hibernate.show_sql" > true </ prop >
            
</ props >
        
</ property >

        
<!--  使用配置文件方式  -->
        
<!--         <property name="mappingResources"> -->
        
<!--             <list> -->
        
<!--                 <value>model/TbUser.hbm.xml</value> -->
        
<!--             </list> -->
        
<!--         </property> -->
    
</ bean >

    
<!-- ======================== 事务配置 ======================== -->
    
<!--  配置事务管理器  -->
    
< bean  id ="transactionManager"
        class
="org.springframework.orm.hibernate3.HibernateTransactionManager" >
        
< property  name ="sessionFactory" >
            
< ref  local ="sessionFactory"   />
        
</ property >
    
</ bean >

    
<!--  配置事务特性 ,配置add、delete和update开始的方法,事务传播特性为required -->
    
< tx:advice  id ="txAdvice"  transaction-manager ="transactionManager" >
        
< tx:attributes >
            
< tx:method  name ="insert*"  propagation ="REQUIRED"   />
            
< tx:method  name ="delete*"  propagation ="REQUIRED"   />
            
< tx:method  name ="update*"  propagation ="REQUIRED"   />
            
< tx:method  name ="*"  read-only ="true"   />
        
</ tx:attributes >
    
</ tx:advice >

    
<!--
        配置那些类的方法进行事务管理,当前com.gts.cns.*.service包中的子包、类中所有方法需要,还需要参考tx:advice的设置
    
-->
    
< aop:config >
        
< aop:pointcut  id ="allManagerMethod"
            expression
="execution (* com.gts.cns.*.service.*.*(..))"   />
        
< aop:advisor  advice-ref ="txAdvice"  pointcut-ref ="allManagerMethod"   />
    
</ aop:config >

</ beans >

 

 

在里面也包含了另一个使用Tomcat的DataSource,已经注释起来了。我后面使用的Jboss,所以就先注释起来了。

最后一个配置文件就是struts.xml的内容了

<? xml version="1.0" encoding="UTF-8"  ?>
<! DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
        "http://struts.apache.org/dtds/struts-2.0.dtd"
>
< struts >
    
< constant  name ="struts.action.extension"  value ="shtml"   />
    
< constant  name ="struts.objectFactory"  value ="spring"   />
    
< include  file ="struts-default.xml"   />

    
< package  name ="default"  extends ="struts-default" >
        
< interceptors >
            
< interceptor-stack  name ="defaultStack" ></ interceptor-stack >
        
</ interceptors >

        
< global-results >
            
< result  name ="error" > /error.jsp </ result >
        
</ global-results >
    
</ package >

    
< include  file ="struts-login.xml"   />
</ struts >

 

 

为了业务区分,我把struts文件放不同文件中

struts-login.xml 的内容

<? xml version="1.0" encoding="UTF-8"  ?>
<! DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
        "http://struts.apache.org/dtds/struts-2.0.dtd"
>
< struts >
    
< package  name ="user"  extends ="default" >

        
<!-- 登录界面  -->
        
< action  name ="login"  class ="com.gts.cns.login.action.UserLoginAction"
            method
="login" >
            
< result  name ="success" >
                /jsp/login.jsp
            
</ result >
        
</ action >
        
< action  name ="loginError"  class ="com.gts.cns.login.action.UserLoginAction"
            method
="error" >
            
< result  name ="success" >
                /jsp/error.jsp
            
</ result >
        
</ action >
        
    
</ package >
</ struts >

 

最后需要贴一下jboss数据库连接的文件mysql-ds.xml。原始的文件在/jboss-4.2.2.GA/docs/examples/jca目录下,然后就看你链接什么数据库了,我使用的是mysql,所以复制了mysql-ds.xml,把它复制到/jboss-4.2.2.GA/server/default/deploy目录下面,因为我的工程是部署在这个下面的。

<? xml version="1.0" encoding="UTF-8" ?>

<!--  $Id: mysql-ds.xml 63175 2007-05-21 16:26:06Z rrajesh $  -->
<!--   Datasource config for MySQL using 3.0.9 available from:
http://www.mysql.com/downloads/api-jdbc-stable.html
-->

< datasources >
  
< local-tx-datasource >
    
< jndi-name > MySqlDS </ jndi-name >
    
< connection-url > jdbc:mysql://127.0.0.1:3306/TPig </ connection-url >
    
< driver-class > com.mysql.jdbc.Driver </ driver-class >
    
< user-name > root </ user-name >
    
< password > admin </ password >
    
< exception-sorter-class-name > org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter </ exception-sorter-class-name >
    
<!--  should only be used on drivers after 3.22.1 with "ping" support
    <valid-connection-checker-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLValidConnectionChecker</valid-connection-checker-class-name>
    
-->
    
<!--  sql to call when connection is created
    <new-connection-sql>some arbitrary sql</new-connection-sql>
      
-->
    
<!--  sql to call on an existing pooled connection when it is obtained from pool - MySQLValidConnectionChecker is preferred for newer drivers
    <check-valid-connection-sql>some arbitrary sql</check-valid-connection-sql>
      
-->

    
<!--  corresponding type-mapping in the standardjbosscmp-jdbc.xml  -->
    
< metadata >
       
< type-mapping > mySQL </ type-mapping >
    
</ metadata >
  
</ local-tx-datasource >
</ datasources >

 

 

 

 接着我这里贴一下我的测试代码

Action部分

/**
 * Create by TPig
 * Since 2010上午09:43:36
 
*/
package  com.gts.cns.login.action;

import  org.springframework.beans.factory.annotation.Autowired;
import  org.springframework.beans.factory.annotation.Qualifier;

import  com.gts.cns.base.BaseAction;
import  com.gts.cns.login.service.IUserLoginService;

/**
 * 类说明:
 * Create by TPig
 * Since 2010上午09:43:36
 
*/
@SuppressWarnings(
" serial " )
public   class  UserLoginAction  extends  BaseAction {

    
/**
     * 用户登录测试接口
     
*/
    @Autowired
    @Qualifier(
" userLoginService " )
    
private  IUserLoginService userLoginService;

    
/**
     * 
@return  the name
     
*/
    
public  String getName() {
        
return  name;
    }

    
/**
     * 
@param  name the name to set
     
*/
    
public   void  setName(String name) {
        
this .name  =  name;
    }

    
public  String login() {
        
this .userLoginService.userTest();
        
this .name  =   " test " ;
        
return  SUCCESS;
    }

    
public  String error() {
        
return  SUCCESS;
    }

    
private  String name;

}

 

 

Service部分

/**
 * Create by TPig
 * Since 2010上午09:47:35
 
*/
package  com.gts.cns.login.service.impl;

import  org.springframework.beans.factory.annotation.Autowired;
import  org.springframework.stereotype.Service;

import  com.gts.cns.base.impl.BaseServiceImpl;
import  com.gts.cns.login.dao.IUserLoginDao;
import  com.gts.cns.login.service.IUserLoginService;

/**
 * 类说明:
 * Create by TPig
 * Since 2010上午09:47:35
 
*/
@Service(
" userLoginService " )
public   class  UserLoginServiceImpl  extends  BaseServiceImpl  implements  IUserLoginService {
    @Autowired
    
private  IUserLoginDao userLoginDao;

    
/*
     * (non-Javadoc)
     * @see com.gts.cns.userlogin.service.IUserLoginService#userTest()
     
*/
    
public  String userTest() {
        System.out.println(
" ==============进入Service================== " );
        
this .userLoginDao.daoTest();
        
return   " test " ;
    }

}

 

 

Dao部分

/**
 * Create by TPig
 * Since 2010上午10:31:15
 
*/
package  com.gts.cns.login.dao.impl;

import  java.util.List;

import  model.TbUser;

import  org.springframework.stereotype.Repository;

import  com.gts.cns.base.impl.BaseDaoImpl;
import  com.gts.cns.login.dao.IUserLoginDao;

/**
 * 类说明:
 * Create by TPig
 * Since 2010上午10:31:15
 
*/
@Repository(
" userLoginDao " )
public   class  UserLoginDaoImpl  extends  BaseDaoImpl  implements  IUserLoginDao {

    
/*
     * (non-Javadoc)
     * @see com.gts.cns.userlogin.dao.IUserLoginDao#daoTest()
     
*/
    @SuppressWarnings(
" unchecked " )
    
public   void  daoTest() {
        System.out.println(
" =================进入DAO================== " );
        String hql 
=   " from TbUser " ;
        List
< TbUser >  userList  =   this .getHibernateTemplate().find(hql);

        
for  (TbUser tbUser : userList) {
            System.out.println(tbUser.getText());
        }
    }

}

 

 

Bean部分

/**
 * Create by TPig
 * Since 2010下午10:39:05
 
*/
package  model;

import  javax.persistence.Column;
import  javax.persistence.Entity;
import  javax.persistence.GeneratedValue;
import  javax.persistence.Id;
import  javax.persistence.Table;

/**
 * 类说明:
 * Create by TPig
 * Since 2010下午10:39:05
 
*/
@Entity
@Table(name
= " tb_user " )
public   class  TbUser {
    @Id
    @GeneratedValue
    @Column(name
= " id " )
    
private   int  id;
    @Column(name
= " user " )
    
private  String user;
    @Column(name
= " text " )
    
private  String text;

    
/**
     * 构造函数
     
*/
    
public  TbUser() {
    }

    
/**
     * 
@return  the id
     
*/
    
public   int  getId() {
        
return  id;
    }

    
/**
     * 
@param  id the id to set
     
*/
    
public   void  setId( int  id) {
        
this .id  =  id;
    }

    
/**
     * 
@return  the user
     
*/
    
public  String getUser() {
        
return  user;
    }

    
/**
     * 
@param  user the user to set
     
*/
    
public   void  setUser(String user) {
        
this .user  =  user;
    }

    
/**
     * 
@return  the text
     
*/
    
public  String getText() {
        
return  text;
    }

    
/**
     * 
@param  text the text to set
     
*/
    
public   void  setText(String text) {
        
this .text  =  text;
    }
}

 

 

  数据库部分我就贴一下图片吧

 

 这个是数据库内容了

 

现在我把jboss启动起来,因为我使用MyEclipse的插件,所以JBoss的配置文件不需要更改

直接启动起来后发现问题了。

Caused by: java.lang.IllegalArgumentException: 'sessionFactory' or 'hibernateTemplate' is required
    at org.springframework.orm.hibernate3.support.HibernateDaoSupport.checkDaoConfig(HibernateDaoSupport.java:117)
    at org.springframework.dao.support.DaoSupport.afterPropertiesSet(DaoSupport.java:44)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1369)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1335)
    ... 150 more

 其中主要看这条错误,告知是sessionFactory或者hibernateTemplate是空的,其实原本我也不知道是怎么一回事,直接就google了,发现已经有人跟到hibernate源码里面去了,并且提示sessionFactory为空的。我也就参照那位仁兄的建议,手动塞进去了。

代码如下:

@Resource(name = " sessionFactory " )
    
public   void  setSuperSessionFactory(SessionFactory sessionFactory){
        
super .setSessionFactory(sessionFactory);
    }

这块代码我就写在了BaseDaoImpl.java中,因为我每一层之上都加了一个base层,我是考虑为今后加统一功能的时候方便,现在就正好派上用场了。然后我再次启动服务器。

问题又来了

Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/classes/applicationContext.xml]: Invocation of init method failed; nested exception is org.hibernate.AnnotationException: java.lang.NoSuchMethodException: org.hibernate.validator.ClassValidator.<init>(java.lang.Class, java.util.ResourceBundle, org.hibernate.validator.MessageInterpolator, java.util.Map, org.hibernate.annotations.common.reflection.ReflectionManager)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1338)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:473)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
    at java.security.AccessController.doPrivileged(Native Method)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:264)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:261)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:185)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:168)
    at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.autowireResource(CommonAnnotationBeanPostProcessor.java:435)
    at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.getResource(CommonAnnotationBeanPostProcessor.java:409)
    at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor$ResourceElement.getResourceToInject(CommonAnnotationBeanPostProcessor.java:537)
    at org.springframework.beans.factory.annotation.InjectionMetadata$InjectedElement.inject(InjectionMetadata.java:192)
    at org.springframework.beans.factory.annotation.InjectionMetadata.injectMethods(InjectionMetadata.java:117)
    at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.postProcessPropertyValues(CommonAnnotationBeanPostProcessor.java:302)
    ... 151 more

 

这个问题就比较折腾了,我当时也无从着手的感觉,网上搜索的也乱七八糟的,有点似是而非的感觉。偶然看到一帖中说到,jboss的hibernate老了,只要删除就可以了。为了以防万一,我将jboss中的hibernate-*.jar全部贴到文件夹外面。然后重启就正常了。

 

接着我再访问这个项目的时候,console打印的消息就是:

14:14:51,203 INFO  [STDOUT] ==============进入Service==================
14:14:51,203 INFO  [STDOUT] =================进入DAO==================
14:14:51,515 INFO  [STDOUT] Hibernate: select tbuser0_.id as id0_, tbuser0_.text as text0_, tbuser0_.user as user0_ from tb_user tbuser0_
14:14:51,562 INFO  [STDOUT] 我来测试一下 

 

后面我一个包一个包的测试,证实了之前帖子中说的,hibernate-annotations.jar这个包的问题。只要将这个包删除就可以了。jboss4.2.2服务器就完全正常了。因为后续功能还没加上去,所以是否还缺少包我就不得而知了,只能一步一步来。希望我遇到的问题的解决方案,能够帮到各位吧。如果有错误,也请提出来。谢谢。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值