2013-11-23 68 views
4

Iam在我的web應用程序中使用Spring Transactional和AspectJ。 應用程序的context.xmlorg.hibernate.HibernateException:沒有配置CurrentSessionContext

<beans xmlns="http://www.springframework.org/schema/beans" 
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
     xmlns:jaxrs="http://cxf.apache.org/jaxrs" 
     xmlns:context="http://www.springframework.org/schema/context" 
     xmlns:util="http://www.springframework.org/schema/util" xmlns:aop="http://www.springframework.org/schema/aop" 
     xmlns:tx="http://www.springframework.org/schema/tx" 
     xsi:schemaLocation=" 
     http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd 
     http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd 
     http://cxf.apache.org/jaxrs http://cxf.apache.org/schemas/jaxrs.xsd 
     http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd 
     http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.1.xsd 
     http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"> 

    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" 
      destroy-method="close"> 
     <property name="driverClassName" value="com.mysql.jdbc.Driver"/> 
     <property name="url" value="jdbc:mysql://localhost:3306/mfdb1_2?useLegacyDatetimeCode=false"/> 
     <property name="username" value="myfashions"/> 
     <property name="password" value="myfashions123"/> 
    </bean> 

    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> 
     <property name="dataSource" ref="dataSource"/> 
     <property name="configLocation" value="classpath:hibernate.cfg.xml"/> 
    </bean> 

    <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> 
     <property name="dataSource" ref="dataSource"/> 
     <property name="sessionFactory" ref="sessionFactory"/> 
    </bean> 
    <context:annotation-config/> 
    <tx:annotation-driven transaction-manager="transactionManager"/> 
    <aop:aspectj-autoproxy/> 
    <context:component-scan base-package=" com.myfashions.dao, com.myfashions.handler, com.myfashions.api"/> 
.. 
.. 

的hibernate.cfg.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE hibernate-configuration PUBLIC 
     "-//Hibernate/Hibernate Configuration DTD 3.0//EN" 
     "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> 
<hibernate-configuration> 
    <session-factory> 
     <!-- Database connection settings --> 
     <!--<property name="connection.driver_class">com.mysql.jdbc.Driver</property> 
     <property name="connection.url">jdbc:mysql://localhost:3306/mfdb1_2?useLegacyDatetimeCode=false 
     </property> 
     <property name="connection.username">myfashions</property> 
     <property name="connection.password">myfashions123</property>--> 

     <!-- BonceCP connection pool --> 
     <property name="hibernate.connection.provider_class">com.jolbox.bonecp.provider.BoneCPConnectionProvider 
     </property> 
     <property name="bonecp.connectionTestStatement">/*ping*/select 1</property> 
     <property name="bonecp.setIdleMaxAgeInMinutes">60</property> 
     <property name="bonecp.setIdleConnectionTestPeriodInMinutes">5</property> 
     <property name="bonecp.partitionCount">3</property> 
     <property name="bonecp.acquireIncrement">2</property> 
     <property name="bonecp.maxConnectionsPerPartition">5</property> 
     <property name="bonecp.minConnectionsPerPartition">2</property> 
     <property name="bonecp.statementsCacheSize">50</property> 
     <property name="bonecp.releaseHelperThreads">3</property> 


     <!-- SQL dialect --> 
     <property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property> 

     <!-- Enable Hibernate's automatic session context management --> 
     <!--<property name="current_session_context_class">thread</property>--> 
</session-factory> 

</hibernate-configuration> 

看點方法:

@Around(value = "@within(com.myfashions.secured.Secured) || @annotation(com.myfashions.secured.Secured)") 
    public Object logAround(ProceedingJoinPoint joinPoint) throws Throwable { 
     System.out.println("method name : " + joinPoint.getSignature().getName()); 
     System.out.println("method arguments : " + Arrays.toString(joinPoint.getArgs())); 
     try { 
      // continue on the intercepted method 
      Object returnObject = joinPoint.proceed(); 
      return returnObject; 
     } catch (Exception e) { 
      e.printStackTrace(); 
      return null; 
     } 
    } 

當我打電話的實現方法,我得到org.hibernate.HibernateException: No CurrentSessionContext configured!例外。你能提一下我出錯的地方嗎?

+0

你把你的application.cfg.xml放在哪裏? – Filipe

回答

4

您已設置SessionFactory的在應用程序的context.xml但在hibernate.cfg.xml你沒有爲會話設置屬性

一套物業:::

<property name="hibernate.current_session_context_class">org.hibernate.context.ThreadLocalSessionContext</property> 

你可以參考以下鏈接: ::

Why do I get org.hibernate.HibernateException: No CurrentSessionContext configured

http://www.coderanch.com/t/559930/ORM/databases/org-hibernate-HibernateException-CurrentSessionContext-configured

+2

對於較新的Hibernate版本:'org.hibernate.context.internal.ThreadLocalSessionContext' –

相關問題