3

SOでこれについて非常に多くの質問があります、しかし私はそれらのいくつかを正しく聞こえるように試しました、しかし私はまだ得ています

org.hibernate.HibernateException: No Session found for current thread

私のサービスレイヤークラスには、次のような注釈が付けられています。

   @Service
   public class MyService {
       @Autowired
       public SomeDao someDao;

       @Transactional
       public void performSomeTransaction() {/* ... */}
   }

私のアプリケーションコンテキストXMLには、次の関連する宣言があります。

    <context:component-scan base-package = "com.myapp.business.dao.impl" />
    <context:component-scan base-package = "com.myapp.business.services" />

    <context:annotation-config />

    <tx:annotation-driven transaction-manager = "transactionManager" />

    <!-- Hibernate -->
    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="hibernateProperties">
            <props>
                <prop key="connection.url">jdbc:mysql://localhost:3306/bidapp</prop>
                <prop key="connection.username">bidapp</prop>
                <prop key="connection.password">pennyfss</prop>
                <prop key="connection.driver_class">com.mysql.jdbc.Driver</prop>

                <prop key="hibernate.connection.pool_size">10</prop>
                <prop key="hibernate.connection.autocommit">false</prop>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>

                <prop key="c3p0.acquireIncrement">1</prop>
                <prop key="c3p0.max_size">50</prop>
                <prop key="c3p0.max_statement">0</prop>
                <prop key="c3p0.min_size">10</prop>
                <prop key="c3p0.timeout">0</prop>
            </props>
        </property>
        <property name="dataSource" ref="dataSource"></property>
        <property name="packagesToScan">
            <list>
                <value>com.bidapp.business.domain</value>
            </list>
        </property>
    </bean>

    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://localhost:3306/bidapp" />
        <property name="username" value="bidapp" />
        <property name="password" value="pennyfss" />
    </bean>

    <bean id="transactionManager"
        class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />
    </bean>

私も私のdispatcher-servlet.xmlファイルを持っています

    <mvc:annotation-driven />
<mvc:default-servlet-handler />

<context:component-scan base-package="com.myapp.presentation.controllers" />
<context:annotation-config />

<bean id="viewResolver" class="org.thymeleaf.spring3.view.ThymeleafViewResolver">
    <property name="templateEngine" ref="templateEngine" />
</bean>

なぜ私のサービスをトランザクションでスプリングラップしないのですか?

したがって、問題はインスタンスを正しく取得できないことに関係しているようです。私は次のShiroセキュリティ設定を持っています:

    <bean id = "hibernateRealm" class = "com.bidapp.presentation.shiro.HibernateRealm" >
        <property name = "credentialsMatcher" ref = "credentialsMatcher" />
    </bean> 

    <bean id = "credentialsMatcher" class = "com.bidapp.presentation.shiro.JasyptCredentialsMatcher" />

    <bean id = "securityManager" class = "org.apache.shiro.web.mgt.DefaultWebSecurityManager">
        <property name = "realm" ref = "hibernateRealm" />
    </bean>

HibernateRealmは、@Transactionalアノテーションが付いたサービスクラスです。ここで作成しているので、Springがプロキシでラップするべきではありません。

4

2 に答える 2

1

この問題の最も一般的な原因は次のとおりです。

  1. サービス インスタンスを誤って取得する: たとえば、Spring からインスタンスを取得するのではなく、自分でインスタンス化する。
  2. Spring MVC アプリケーションでルートおよび子アプリケーション コンテキストを誤って構成する。私はここでこれらの質問のかなりの数に答えました。より教育的なもののいくつかを次に示します。

Spring XML ファイル構成階層のヘルプ/説明

親コンテキストと子コンテキストでSpring Beanを宣言する

サービス インスタンスを取得して使用するコードを示すと、問題の特定に役立ちます。

于 2013-01-25T03:59:45.567 に答える