在我目前的spring-boot项目中,我有这个课程:
@Component
public class OauthTokenStore extends JdbcTokenStore {
public OauthTokenStore() {
super(...);
}
}
super(...)
的属性应该是有效的数据源。我在application.properties
:
# jdbc.X
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost/lojacms
spring.datasource.username=root
spring.datasource.password=
# hibernate.X
spring.jpa.database-platform=org.hibernate.dialect.MySQL5Dialect
spring.jpa.dialect=org.hibernate.dialect.MySQL5Dialect
spring.jpa.show-sql=false
spring.jpa.hibernate.ddl-auto=validate
有没有办法创建数据源的实例并在此构造函数中使用?
答案 0 :(得分:0)
您需要注入DataSource
bean,然后使用OauthTokenStore
将其传递给@Inject
构造函数。
@Component
public class OauthTokenStore extends JdbcTokenStore {
@Inject
public OauthTokenStore(DataSource ds) {
super(ds);
}
}
如果你的应用程序中还没有定义DataSource
类型的bean,你需要一个:
@Configuration
public class Config {
@Bean
public DriverManagerDataSource dataSource() {
DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost/lojacms");
dataSource.setUsername("root");
dataSource.setPassword("");
return dataSource;
}
}