oauth2.0 java.sql.SQLException:网址不能为空[多模块应用]

w3nuxt5m  于 2023-10-15  发布在  Java
关注(0)|答案(1)|浏览(149)

我想使用oauth2服务器访问我的web应用程序。
身份验证顺利通过,我被重定向到我的Web应用程序。
但问题是,当我试图从我的数据库中加载数据时,
例外:

janv. 31, 2017 1:16:07 PM org.apache.tomcat.jdbc.pool.PooledConnection connectUsingDriver
    AVERTISSEMENT: Not loading a JDBC driver as driverClassName property is null.
    janv. 31, 2017 1:16:07 PM org.apache.tomcat.jdbc.pool.ConnectionPool init
    GRAVE: Unable to create initial connections of pool.
    java.sql.SQLException: The url cannot be null

有人能帮帮我吗。

编辑:

我有一个单独的配置模块,我设置我的数据库连接。我把这个模块作为一个依赖添加到我的Web应用程序中。
我的application.properties文件

# DataSource configuration
datasource.host=localhost
datasource.name=my-db
datasource.port=5432

datasource.username=my-user
datasource.password=my-password

datasource.url=jdbc:postgresql://${datasource.host}:${datasource.port}/${datasource.name}
datasource.driver.class.name=org.postgresql.Driver

我的配置类(我像ORM一样使用myBatis)

@Configuration
@MapperScan(basePackages = {"com.package.mapper"})
@ComponentScan(basePackages = {"com.package.repository"})
public class MyBatisConfig {

  @Value("${datasource.driver.class.name}")
  private String dbDriverClassName;

  @Value("${datasource.url}")
  private String dbUrl;

  @Value("${datasource.username}")
  private String dbUsername;

  @Value("${datasource.password}")
  private String dbPassword;

  @Bean
  public DataSource getDataSource() {
    return DataSourceBuilder
        .create()
        .url(dbUrl)
        .driverClassName(dbDriverClassName)
        .username(dbUsername)
        .password(dbPassword)
        .build();
  }

  @Bean
  public SqlSessionFactory sqlSessionFactory() throws Exception {
    SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
    sessionFactory.setConfigLocation(new ClassPathResource("META-INF/spring/mybatis-config.xml"));
    sessionFactory.setDataSource(getDataSource());
    return sessionFactory.getObject();
  }

  @Bean
  public DataSourceTransactionManager transactionManager() {
    return new DataSourceTransactionManager(getDataSource());
  }
}
nkhmeac6

nkhmeac61#

我认为你必须在配置文件中设置DB连接。因为,从你发布的异常中,我可以看到你没有加载JDBC DriverManager的驱动程序和访问数据库的URL。

"driverClassName" value="oracle.jdbc.OracleDriver" 
"url" value="jdbc:oracle:thin:@localhost:1521:xe"
"username" value="user"
"password" value="password"

这是一个简单的例子。如果我错了,请编辑您的文章与您的配置数据库连接。

相关问题