Spring JPA не может подключиться к Postgresql

#postgresql #spring-boot #spring-data #spring-data-jpa

#postgresql #spring-boot #spring-данные #spring-data-jpa

Вопрос:

Я пытаюсь написать JPA-приложение Spring Data с помощью Postgres.

Я получаю сообщение об ошибке: FATAL: password authentication failed for user

Я попробовал то же самое, написав соединение с использованием обычного JDBC, и все работало нормально, то же имя пользователя / пароль / база данных / имя хоста.

Файл свойств, который я использую для Spring Data JPA, содержит следующее:

 spring.jpa.database=POSTGRESQL
spring.datasource.platform=postgres
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=create-drop
spring.database.driverClassName=org.postgresql.Driver
spring.datasource.url=jdbc:postgresql://localhost:5432/testdb
spring.datasource.username=test_java 
spring.datasource.password=easy_password
server.port=8080
 

По сравнению с файлом свойств, который я использую для теста java jdbc:

 db.url=jdbc:postgresql://localhost:5432/testdb
db.user=test_java
db.passwd=easy_password
 

Код Java выглядит следующим образом:

 public void testSelectWithPropertyFile() {
    Logger lgr = Logger.getLogger(getClass().getName());
    Connection con = null;
    PreparedStatement pst = null;
    ResultSet rs = null;

    Properties props = new Properties();
    FileInputStream in = null;

    try {
        in = new FileInputStream("target/classes/properties/database.properties");
        props.load(in);

    } catch (IOException ex) {
        lgr.log(Level.SEVERE, ex.getMessage(), ex);
        return;
    } finally {

        try {
            if (in != null) {
                in.close();
            }
        } catch (IOException ex) {
            lgr.log(Level.SEVERE, ex.getMessage(), ex);
        }
    }

    String url = props.getProperty("db.url");
    String user = props.getProperty("db.user");
    String passwd = props.getProperty("db.passwd");

    try {

        con = DriverManager.getConnection(url, user, passwd);
        pst = con.prepareStatement("SELECT * FROM Authors");
        rs = pst.executeQuery();

        while (rs.next()) {
            System.out.print(rs.getInt(1));
            System.out.print(": ");
            System.out.println(rs.getString(2));
        }

    } catch (Exception ex) {
        lgr.log(Level.SEVERE, ex.getMessage(), ex);

    } finally {

        try {
            if (rs != null) {
                rs.close();
            }
            if (pst != null) {
                pst.close();
            }
            if (con != null) {
                con.close();
            }

        } catch (SQLException ex) {
            lgr.log(Level.WARNING, ex.getMessage(), ex);
        }
    }
}
 

Вот журнал ошибок, который я получаю в Spring Boot JPA:

 2016-10-14 11:09:21.593  INFO 6948 --- [           main] com.example.JpaPostgresApplication       : Starting JpaPostgresApplication on DESKTOP-53J32BH with PID 6948 (C:UserscharbworkspaceJPA_POSTGREStargetclasses started by charb in C:UserscharbworkspaceJPA_POSTGRES)
    2016-10-14 11:09:21.595  INFO 6948 --- [           main] com.example.JpaPostgresApplication       : No active profile set, falling back to default profiles: default
    2016-10-14 11:09:21.679  INFO 6948 --- [           main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@72f926e6: startup date [Fri Oct 14 11:09:21 BST 2016]; root of context hierarchy
    2016-10-14 11:09:23.402  INFO 6948 --- [           main] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration' of type [class org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration$EnhancerBySpringCGLIB$72d9bd3b] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying)
    2016-10-14 11:09:23.922  INFO 6948 --- [           main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port(s): 8080 (http)
    2016-10-14 11:09:23.933  INFO 6948 --- [           main] o.apache.catalina.core.StandardService   : Starting service Tomcat
    2016-10-14 11:09:23.934  INFO 6948 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet Engine: Apache Tomcat/8.5.5
    2016-10-14 11:09:24.062  INFO 6948 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
    2016-10-14 11:09:24.062  INFO 6948 --- [ost-startStop-1] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 2387 ms
    2016-10-14 11:09:24.230  INFO 6948 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean  : Mapping servlet: 'dispatcherServlet' to [/]
    2016-10-14 11:09:24.234  INFO 6948 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'characterEncodingFilter' to: [/*]
    2016-10-14 11:09:24.235  INFO 6948 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
    2016-10-14 11:09:24.235  INFO 6948 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'httpPutFormContentFilter' to: [/*]
    2016-10-14 11:09:24.235  INFO 6948 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'requestContextFilter' to: [/*]
    2016-10-14 11:09:24.478  INFO 6948 --- [           main] j.LocalContainerEntityManagerFactoryBean : Building JPA container EntityManagerFactory for persistence unit 'default'
    2016-10-14 11:09:24.492  INFO 6948 --- [           main] o.hibernate.jpa.internal.util.LogHelper  : HHH000204: Processing PersistenceUnitInfo [
        name: default
        ...]
    2016-10-14 11:09:24.554  INFO 6948 --- [           main] org.hibernate.Version                    : HHH000412: Hibernate Core {5.0.11.Final}
    2016-10-14 11:09:24.555  INFO 6948 --- [           main] org.hibernate.cfg.Environment            : HHH000206: hibernate.properties not found
    2016-10-14 11:09:24.557  INFO 6948 --- [           main] org.hibernate.cfg.Environment            : HHH000021: Bytecode provider name : javassist
    2016-10-14 11:09:24.602  INFO 6948 --- [           main] o.hibernate.annotations.common.Version   : HCANN000001: Hibernate Commons Annotations {5.0.1.Final}
    2016-10-14 11:09:24.828 ERROR 6948 --- [           main] o.a.tomcat.jdbc.pool.ConnectionPool      : Unable to create initial connections of pool.

    org.postgresql.util.PSQLException: FATAL: password authentication failed for user "test_java "
        at org.postgresql.core.v3.ConnectionFactoryImpl.doAuthentication(ConnectionFactoryImpl.java:446) ~[postgresql-9.4.1211.jre7.jar:9.4.1211.jre7]
        at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:220) ~[postgresql-9.4.1211.jre7.jar:9.4.1211.jre7]
 

Я не могу понять, почему Spring Data JPA не может пройти аутентификацию, в то время как обычный java JDBC работает нормально.

Комментарии:

1. В вашем файле свойств spring config после него есть пробел ...username=test_java (в то время как в ваших тестовых свойствах пробела нет).

2. Спасибо! вот и все!!! вы должны были ответить в ответе, чтобы я мог принять его! в любом случае спасибо!

3. какова логика для тестирования jdbc с запуском всего контекста приложения spring boot и при использовании уровня абстракции Spring JPA над jdbc?

Ответ №1:

Заменить spring.database.driverClassName=org.postgresql.Driver на spring.datasource.driverClassName=org.postgresql.Driver

Ответ №2:

Ваша проблема заключается в аутентификации,

Сообщение Se

ошибка аутентификации по паролю для пользователя «test_java»

Уверены ли вы в правильности этого информационного соединения? потому что это ваша проблема, если это правильно, тогда сделайте тест, подключите тот же другой клиент в вашей базе, с локальным.

  • Если все в порядке. проблема не в возможности удаленного подключения.
  • Для возможности подключения удаленного доступа pg_hba.config затем возможность удаленного подключения (или другой файл, который настраивает вашу базу данных)

Смотрите: эта часть моей конфигурации файла:

 # IPv4 local connections:
host    all             all             127.0.0.1/32            md5
host    all             all             192.168.2.0/24            md5
 

разрешение подключения к локальной сети и сети 192.168.2.0 имеет множество способов настройки, которые

Комментарии:

1. Если pg_hba.conf бы это была проблема, сообщение об ошибке было бы другим

2. вы пытались установить удаленное или локальное соединение?

3. комментарий @pozs ответил на это, это был пробел в имени пользователя после java_user