我在Web应用程序中使用Spring Transactional和AspectJ。
application-context.xml
<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!
异常。能否请您提及我哪里出问题了。 最佳答案
您已经在application-context.xml中设置了sessionFactory,但是在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