1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Tomcat - DatasourceJNDI

Boa noite. Estou com problemas para subir uma aplicação, utilizando JNDI no tomcat. Ao tentar subir o servidor recebo a seguinte exceção:

GRAVE: Exception starting filter conexaoFiter
java.lang.ExceptionInInitializerError
    at financeiro.util.HibernateUtil.buildSessionFactory(HibernateUtil.java:37)
    at financeiro.util.HibernateUtil.<clinit>(HibernateUtil.java:27)
    at financeiro.web.filter.ConexaoHibernateFilter.init(ConexaoHibernateFilter.java:49)
    at org.apache.catalina.core.ApplicationFilterConfig.initFilter(ApplicationFilterConfig.java:279)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:260)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:105)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4603)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5210)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1396)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1386)
    at java.util.concurrent.FutureTask.run(FutureTask.java:262)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    at java.lang.Thread.run(Thread.java:745)
Caused by: java.lang.AbstractMethodError: org.postgresql.jdbc3g.Jdbc3gConnection.isValid(I)Z
    at org.apache.tomcat.dbcp.dbcp2.DelegatingConnection.isValid(DelegatingConnection.java:913)
    at org.apache.tomcat.dbcp.dbcp2.PoolableConnection.validate(PoolableConnection.java:226)
    at org.apache.tomcat.dbcp.dbcp2.PoolableConnectionFactory.validateConnection(PoolableConnectionFactory.java:302)
    at org.apache.tomcat.dbcp.dbcp2.BasicDataSource.validateConnectionFactory(BasicDataSource.java:2164)
    at org.apache.tomcat.dbcp.dbcp2.BasicDataSource.createPoolableConnectionFactory(BasicDataSource.java:2147)
    at org.apache.tomcat.dbcp.dbcp2.BasicDataSource.createDataSource(BasicDataSource.java:1902)
    at org.apache.tomcat.dbcp.dbcp2.BasicDataSource.getConnection(BasicDataSource.java:1412)
    at org.hibernate.connection.DatasourceConnectionProvider.getConnection(DatasourceConnectionProvider.java:92)
    at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:114)
    at org.hibernate.cfg.Configuration.buildSettingsInternal(Configuration.java:2163)
    at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2159)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1383)
    at org.hibernate.cfg.AnnotationConfiguration.buildSessionFactory(AnnotationConfiguration.java:954)
    at financeiro.util.HibernateUtil.buildSessionFactory(HibernateUtil.java:34)
    ... 14 more

Pontos que destaco: Já adicionei o drive do postgres no classpath, e também já adicionei o mesmo driver na pasta lib do tomcat.

Na sequência segue: - web.xml

    <filter>
        <filter-name>conexaoFilter</filter-name>
        <filter-class>financeiro.web.filter.ConexaoHibernateFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>conexaoFilter</filter-name>
        <url-pattern>*.xhtml</url-pattern>
    </filter-mapping>

    <resource-ref>
        <description>DataSource FinaceiroBD</description>
        <res-ref-name>jdbc/financeiroDB</res-ref-name>
        <res-type>javax.sql.DataSource</res-type>
        <res-auth>Container</res-auth>
    </resource-ref>
  • context.xml
<?xml version="1.0" encoding="UTF-8"?>
<Context reloadable="true">
    <Resource    name="jdbc/financeiroDB" 
                auth="Container" 
                type="javax.sql.DataSource"
                maxActive="100" 
                maxIdle="30" 
                maxWait="10000"
                username="postgres" 
                password="postgres" 
                driverClassName="org.postgresql.Driver"
                url="jdbc:postgresql://localhost:5432/financeiroWeb?autoReconnect=true"/>
</Context>

Agradeço a todos que poderem me ajudar a resolver esse problema.
Estou usando:
- Tomcat 8.0
- JSF 2.0
- Postgres 9.0
  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

0 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags web.xml ou faça a sua própria pergunta.