Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> stateless EJB и инжект hibernateSession 
:(
    Опции темы
surly
Дата 8.10.2010, 11:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 28
Регистрация: 20.1.2007

Репутация: нет
Всего: нет



добрый день.
захотелось попробывать привязать хибернейт к 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





Это сообщение отредактировал(а) surly - 8.10.2010, 11:56
PM MAIL   Вверх
MisterCleric
Дата 8.10.2010, 12:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1043
Регистрация: 16.2.2006
Где: Харьков, Украина

Репутация: 33
Всего: 38



Привет.
напиши так:
Код

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


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


--------------------
ПРИШЕЛ, УВИДЕЛ - ПЕРЕПИСАЛ...
PM MAIL ICQ   Вверх
surly
Дата 8.10.2010, 12:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 28
Регистрация: 20.1.2007

Репутация: нет
Всего: нет



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




Это сообщение отредактировал(а) surly - 8.10.2010, 12:54
PM MAIL   Вверх
MisterCleric
Дата 8.10.2010, 13:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1043
Регистрация: 16.2.2006
Где: Харьков, Украина

Репутация: 33
Всего: 38



Цитата

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

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


--------------------
ПРИШЕЛ, УВИДЕЛ - ПЕРЕПИСАЛ...
PM MAIL ICQ   Вверх
surly
Дата 8.10.2010, 14:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 28
Регистрация: 20.1.2007

Репутация: нет
Всего: нет



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

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




Это сообщение отредактировал(а) surly - 8.10.2010, 14:44
PM MAIL   Вверх
MisterCleric
Дата 8.10.2010, 14:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1043
Регистрация: 16.2.2006
Где: Харьков, Украина

Репутация: 33
Всего: 38



нет. На оборот. У тебя в классе DAO поле session есть типа org.jboss.seam.web.Session


--------------------
ПРИШЕЛ, УВИДЕЛ - ПЕРЕПИСАЛ...
PM MAIL ICQ   Вверх
surly
Дата 8.10.2010, 14:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 28
Регистрация: 20.1.2007

Репутация: нет
Всего: нет



Код

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 - я не использую, да и пока незачем.

Это сообщение отредактировал(а) surly - 8.10.2010, 14:52
PM MAIL   Вверх
MisterCleric
Дата 8.10.2010, 15:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1043
Регистрация: 16.2.2006
Где: Харьков, Украина

Репутация: 33
Всего: 38



Хорошо.
А переименую этот филд в "hibernateSession"


--------------------
ПРИШЕЛ, УВИДЕЛ - ПЕРЕПИСАЛ...
PM MAIL ICQ   Вверх
surly
Дата 8.10.2010, 15:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 28
Регистрация: 20.1.2007

Репутация: нет
Всего: нет



 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 присутствует.


ХЗ :(

Это сообщение отредактировал(а) surly - 8.10.2010, 15:50
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.1042 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.