Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Java EE (J2EE) и Spring > stateless EJB и инжект hibernateSession


Автор: surly 8.10.2010, 11:53
добрый день.
захотелось попробывать привязать хибернейт к ejb (т.е. фактически работать с даными не через JPA, а через hibernate).
столкнулся с проблемой иньекции готовой сессии в stateless ejb.
крутится все на jBoss 5.1, фреймворк Seam 2.2.0.
в момент иньекции происходит краш с ошибкой
Цитата

11:40:04,018 INFO  [STDOUT] INIT mysession bean
11:40:04,277 ERROR [TxPolicy] javax.ejb.EJBTransactionRolledbackException: @In attribute requires non-null value: mysession.hibernateSession
.........stacktrace...............

stateless bean, DAO класс, который наследуется stateless bean'ом, интерфейс бина.
Код

public class DAO {
    protected DAO() {
       }
                 /* методы */
       private static final Logger log = Logger.getAnonymousLogger();
                 /* та самая иньекция */
       @In("hibernateSession")
       static Session session;
       // вроде фактори инжектится правильно
       @PersistenceUnit(unitName="seam_test")
       SessionFactory sessionFactory;
}

@Stateless
@Name("mysession")
public class mysession extends DAO implements mysessionLocal {
    @PostConstruct
    public void init() {
        System.out.println("INIT mysession bean");
    }
/* методы */
}
@Local
public interface mysessionLocal {
    String addRecord() throws AdException;
    String deleteRecord() throws AdException;
    Collection<myentity> getAllRecords() throws AdException;
    String deleteRecord(myentity rec) throws AdException;
    void mytest();
}


файлы настройки:
seam_test-ds.xml
Код

<datasources>
     <local-tx-datasource>
      <jndi-name>seam_testDatasource</jndi-name>
      <use-java-context>true</use-java-context>
      <connection-url>jdbc:mysql://localhost:3306/seam</connection-url>
      <driver-class>com.mysql.jdbc.Driver</driver-class>
      <user-name>surly</user-name>
     <password></password>
      </local-tx-datasource>
    </datasources>

components.xml
Код

<web:hot-deploy-filter url-pattern="*.seam"/>
 <!-- 
   <persistence:managed-persistence-context name="entityManager" auto-create="true"
                      persistence-unit-jndi-name="java:/seam_testEntityManagerFactory"/>
-->

 <persistence:hibernate-session-factory cfg-resource-name="hibernate.cfg.xml" 
                    name="hibernateSessionFactory"/>
 <persistence:managed-hibernate-session name="hibernateSession" 
                    session-factory-jndi-name="hibernateSessionFactory" 
                    session-factory="hibernateSessionFactory"/>
  <!-- 
   правила для друлс, и по мелочи
-->
</components>

persistance.xml
Код

 <persistence-unit name="seam_test" transaction-type="JTA">
      <provider>org.hibernate.ejb.HibernatePersistence</provider>
      <jta-data-source>java:/seam_testDatasource</jta-data-source>
      <properties>
         <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
         <property name="hibernate.hbm2ddl.auto" value="create-drop"/>
         <property name="hibernate.show_sql" value="true"/>
         <property name="hibernate.format_sql" value="true"/>
         <property name="jboss.entity.manager.factory.jndi.name" value="myfactory"/>
      </properties>
   </persistence-unit>


hibernate.cfg.xml
Код

<hibernate-configuration>
 <session-factory name="hibernateSessionFactory">
  <property name="hibernate.connection.pool_size">10</property>
  <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
  <property name="hibernate.connection.url">jdbc:mysql://localhost/seam</property>
  <property name="hibernate.connection.username">surly</property>
  <property name="hibernate.show_sql">true</property>
  <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
  <property name="hibernate.format_sql">true</property>
  <property name="hibernate.default_entity_mode">pojo</property>
  <property name="hibernate.session_factory_name">hibernateSessionFactory</property>
  <property name="hibernate.connection.datasource">seam_testDatasource</property>
  <property name="hibernate.transaction.manager_lookup_class">org.hibernate.transaction.JBossTransactionManagerLookup</property>
  <property name="hibernate.transaction.factory_class">org.hibernate.transaction.JTATransactionFactory</property>
  <property name="hibernate.transaction.auto_close_session">false</property>
  <property name="hibernate.cache.provider_class">org.hibernate.cache.HashtableCacheProvider</property>
  <property name="hibernate.transaction.flush_before_completion">true</property>
  <!--  <mapping class="myentity" package="org.domain.seamtest.session"/> -->
 </session-factory>
</hibernate-configuration>



Очень прошу помоч с иньекцией готовой хибернейт сессии.
так же, оч интерестно, но sessionFactory инжектится отлично, вроде как smile




Автор: MisterCleric 8.10.2010, 12:21
Привет.
напиши так:
Код

<persistence:managed-hibernate-session name="hibernateSession" 
                    session-factory-jndi-name="hibernateSessionFactory" 
                    session-factory="hibernateSessionFactory"
auto-create="true"/> <!--вот это надо для того, что бы не ругался @In-->


Да, и почему у тебя session static field?

Автор: surly 8.10.2010, 12:53
DAO.java я взял с прошлого проекта, много не менял, но спасибо smile фиксанул.
прописал fauto-create=true.
теперь ругается на другоеsmile
Цитата

12:45:59,238 ERROR [TxPolicy] javax.ejb.EJBTransactionRolledbackException: could not set field value: mysession.session
12:45:59,244 SEVERE [application] javax.ejb.EJBTransactionRolledbackException: could not set field value: mysession.session

и по трейсу
Цитата

Could not set field value by reflection: DAO.session on: org.domain.seamtest.session.DAO with value: class org.jboss.seam.web.Session
...
Can not set org.hibernate.Session field org.domain.seamtest.session.DAO.session to org.jboss.seam.web.Session



Автор: MisterCleric 8.10.2010, 13:31
Цитата

org.hibernate.Session field org.domain.seamtest.session.DAO.session to org.jboss.seam.web.Session

Читаем внимательно пакеты классов

Автор: surly 8.10.2010, 14:29
эм, не понимаю..
наверно совсем плохой стал :(

я вижу, что сим пытается запихнуть в org.hibernate.session  обьект типа org.jboss.seam.web.Session.
но мне же нужен совсем не этот обьект.



Автор: MisterCleric 8.10.2010, 14:48
нет. На оборот. У тебя в классе DAO поле session есть типа org.jboss.seam.web.Session

Автор: surly 8.10.2010, 14:51
Код

import java.util.logging.Level;
import java.util.logging.Logger;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.jboss.seam.annotations.In;


мои импорты
org.jboss.seam.web.Session - я не использую, да и пока незачем.

Автор: MisterCleric 8.10.2010, 15:07
Хорошо.
А переименую этот филд в "hibernateSession"

Автор: surly 8.10.2010, 15:36
 smile  
теперь другая ашибка, т.е. уже на имя поля не ругается smile
Цитата

15:47:59,627 ERROR [TxPolicy] javax.ejb.EJBTransactionRolledbackException: java.lang.String cannot be cast to org.hibernate.SessionFactory
15:47:59,654 SEVERE [application] javax.ejb.EJBTransactionRolledbackException: java.lang.String cannot be cast to org.hibernate.SessionFactory

какого черта ?( никто никогда не инжектил сесию хибернейта в ejb? 

а еще вот пересмотрел лог старта приложения, увидел такие строки :
Цитата

12:41:12,936 INFO  [Configuration] configuring from resource: hibernate.cfg.xml
12:41:12,937 INFO  [Configuration] Configuration resource: hibernate.cfg.xml
12:41:12,964 INFO  [Configuration] Configured SessionFactory: null

........

12:41:13,248 INFO  [SettingsFactory] Default entity-mode: pojo
12:41:13,248 INFO  [SettingsFactory] Named query checking : enabled
12:41:13,266 INFO  [SessionFactoryImpl] building session factory
12:41:13,266 INFO  [SessionFactoryObjectFactory] Not binding factory to JNDI, no JNDI name configured
12:41:13,276 INFO  [SchemaUpdate] Running hbm2ddl schema update
12:41:13,277 INFO  [SchemaUpdate] fetching database metadata


по последнему  - JTA.lib присутствует.


ХЗ :(

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)