Maven + Hibernate + Postgres-JDBC

Poxa, não consigo de modo algum fazer minha aplicação web se conectar ao PostgreSQL.

Sempre monstra o erro abaixo:

Grave: Initial SessionFactory creation failed.org.hibernate.boot.registry.classloading.spi.ClassLoadingException: Unable to load class [org.postgresql.Driver]

Estou usando o **GlassFish 4.1.**1 com Netbeans 8.1 e parece que ele não ta enxergando o Drive Jdbc do Postgres. Em qualquer teste sem o Maven não acontece esse problema. Na lista de dependência o driver do postgres esta lá. Mas não consigo conectar ao banco.

POM.xml


<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>br.com.sistema</groupId>
    <artifactId>ControleEscolar</artifactId>
    <version>1.00-SNAPSHOT</version>
    <packaging>war</packaging>

    <name>Sistema</name>

    <properties>
        <endorsed.dir>${project.build.directory}/endorsed</endorsed.dir>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>
    
    <dependencies>
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-web-api</artifactId>
            <version>7.0</version>
            <scope>provided</scope>
        </dependency>
        
        <dependency>
            <groupId>org.primefaces</groupId>
            <artifactId>primefaces</artifactId>
            <version>5.0</version>
        </dependency>
        <!--
        <dependency>
            <groupId>org.jboss.weld.servlet</groupId>
            <artifactId>weld-servlet</artifactId>
            <version>2.2.9.Final</version>
            <scope>compile</scope>
        </dependency>
    -->    
        <dependency>
                <groupId>org.jboss</groupId>
            <artifactId>jandex</artifactId>
            <version>1.2.2.Final</version>
            <scope>compile</scope>
        </dependency>

        <dependency>
                <groupId>org.hibernate</groupId>
                <artifactId>hibernate-validator</artifactId>
                <version>5.1.3.Final</version>
                <scope>compile</scope>
        </dependency>

        <dependency>
                <groupId>org.glassfish</groupId>
                <artifactId>javax.faces</artifactId>
                <version>2.2.10</version>
                <scope>compile</scope>
        </dependency>

        <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>javax.servlet-api</artifactId>
                <version>3.1.0</version>
                <scope>provided</scope>
        </dependency>

        <dependency>
                <groupId>org.hibernate</groupId>
                <artifactId>hibernate-core</artifactId>
                <version>4.3.6.Final</version>
                <scope>compile</scope>
        </dependency>

        <dependency>
                <groupId>org.hibernate</groupId>
                <artifactId>hibernate-entitymanager</artifactId>
                <version>4.3.8.Final</version>
                <scope>compile</scope>
        </dependency>
<dependency>
    <groupId>org.postgresql</groupId>
    <artifactId>postgresql</artifactId>
    <version>VERSION</version>
</dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.1</version>
                <configuration>
                    <source>1.7</source>
                    <target>1.7</target>
                    <compilerArguments>
                        <endorseddirs>${endorsed.dir}</endorseddirs>
                    </compilerArguments>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.3</version>
                <configuration>
                    <failOnMissingWebXml>false</failOnMissingWebXml>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-dependency-plugin</artifactId>
                <version>2.6</version>
                <executions>
                    <execution>
                        <phase>validate</phase>
                        <goals>
                            <goal>copy</goal>
                        </goals>
                        <configuration>
                            <outputDirectory>${endorsed.dir}</outputDirectory>
                            <silent>true</silent>
                            <artifactItems>
                                <artifactItem>
                                    <groupId>javax</groupId>
                                    <artifactId>javaee-endorsed-api</artifactId>
                                    <version>7.0</version>
                                    <type>jar</type>
                                </artifactItem>
                            </artifactItems>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

</project>

Onde esta a configuração de conexão com o banco?

hibernate.cfg.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
  <session-factory>
    <property name="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</property>
    <property name="hibernate.connection.driver_class">org.postgresql.Driver</property>
    <property name="hibernate.connection.url">jdbc:postgresql://localhost:5432/sistema</property>
    <property name="hibernate.connection.username">postgres</property>
    <property name="hibernate.connection.password">postgres</property>
    <property name="hibernate.hbm2ddl.auto">update</property>
    <property name="hibernate.show_sql">true</property>
    <mapping class="model.Usuario"/>
  </session-factory>
</hibernate-configuration>


1 curtida

O que você colocou no <version>VERSION</version> na configuração do postgresql no seu maven? Você só tem uma versão do postgresql instalada no seu computador ou servidor?

Poxa, tinha deixado como esta <version>VERSION</version>. Estou usando o Postgres 9.2, mas ja coloquei a versão no POM e não funcionou.

Já coloquei

9.2
9.2-1004-jdbc41
9.2-1004-jdbc4
9.2-1004-jdbc3
9.2-1003-jdbc4
9.2-1003-jdbc3
9.2-1002-jdbc4

E nenhum deles tirou o erro, to quase desistindo do Maven.

Sem o Maven, adiciono a biblioteca direto na propriedade da aplicação e funciona, agora o no Maven não tem essa opção.

Grave: Initial SessionFactory creation failed.org.hibernate.boot.registry.classloading.spi.ClassLoadingException: Unable to load class [org.postgresql.Driver]

Estranho… substituindo o VERSION, bastava dar um build no projeto que a biblioteca é carregada… vc está usando qual IDE?

Desiste do Maven não ele é uma mão na roda. De noite vou ver como fiz em casa e te envio.

Netbeans.

eu não sei como funciona no Netbeans… No Eclipse, duas coisas que você poderia verificar são: primeiro, verificar se o build do projeto está automático ou se você precisar fazer o build. Algumas pessoas gostam de manter o automático, outras preferem fazer o build uma única vez. A segunda, clicando-se com o lado direito no projeto -> Maven -> update project, você pode dar um update no seu projeto. Inclusive nessa opção você pode selecionar um item que força a obtenção da dependência a partir do repositório. Eu recomendaria você dar uma olhada como funciona isso no netbeans e ver se resolve o seu problema. O restante parece estar correto.