- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
尝试使用 spring-boot-starter-data-jpa
启动我的 spring boot 项目时,我遇到了这个奇怪的错误。奇怪的是,我的应用程序会在我添加几个存储库和服务之前启动,但我似乎无法缩小为什么 spring 无法初始化在添加之前工作的存储库的原因。
相关错误如下:
11:38:42.313 INFO org.hibernate.Version.logVersion() @37 [localhost-startStop-1] - HHH000412: Hibernate Core {5.0.11.Final}
11:38:42.316 INFO org.hibernate.cfg.Environment.<clinit>() @213 [localhost-startStop-1] - HHH000206: hibernate.properties not found
11:38:42.319 INFO org.hibernate.cfg.Environment.buildBytecodeProvider() @317 [localhost-startStop-1] - HHH000021: Bytecode provider name : javassist
11:38:42.430 INFO org.hibernate.annotations.common.Version.<clinit>() @66 [localhost-startStop-1] - HCANN000001: Hibernate Commons Annotations {5.0.1.Final}
11:38:43.165 INFO org.hibernate.dialect.Dialect.<init>() @156 [localhost-startStop-1] - HHH000400: Using dialect: org.hibernate.dialect.MySQL5Dialect
11:38:43.583 ERROR org.springframework.boot.context.embedded.tomcat.TomcatStarter.onStartup() @63 [localhost-startStop-1] - Error starting Tomcat context. Exception: org.springframework.beans.factory.BeanCreationException. Message: Error creating bean with name 'emailAuthenticationFilter' defined in class path resource [gg/leet/security/WebSecurityConfig.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [gg.leet.security.EmailAuthenticationFilter]: Factory method 'emailAuthenticationFilter' threw exception; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'authenticationManager' defined in class path resource [gg/leet/security/WebSecurityConfig.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.springframework.security.authentication.AuthenticationManager]: Factory method 'authenticationManager' threw exception; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'emailAuthenticationProvider': Unsatisfied dependency expressed through field 'userService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'userServiceImpl' defined in file [/Users/andrew/Programs/leet-tournaments/backend/build/classes/main/gg/leet/service/UserServiceImpl.class]: Unsatisfied dependency expressed through constructor parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userRepository': Cannot create inner bean '(inner bean)#76212c93' of type [org.springframework.orm.jpa.SharedEntityManagerCreator] while setting bean property 'entityManager'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name '(inner bean)#76212c93': Cannot resolve reference to bean 'entityManagerFactory' while setting constructor argument; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaAutoConfiguration.class]: Invocation of init method failed; nested exception is javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory
11:38:43.617 WARN org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext.refresh() @550 [restartedMain] - Exception encountered during context initialization - cancelling refresh attempt: org.springframework.context.ApplicationContextException: Unable to start embedded container; nested exception is org.springframework.boot.context.embedded.EmbeddedServletContainerException: Unable to start embedded Tomcat
11:38:43.631 ERROR org.springframework.boot.SpringApplication.reportFailure() @839 [restartedMain] - Application startup failed
最有趣的是这句话:
11:38:43.583 ERROR org.springframework.boot.context.embedded.tomcat.TomcatStarter.onStartup() @63 [localhost-startStop-1] - Error starting Tomcat context. Exception: org.springframework.beans.factory.BeanCreationException. Message: Error creating bean with name 'emailAuthenticationFilter' defined in class path resource [gg/leet/security/WebSecurityConfig.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [gg.leet.security.EmailAuthenticationFilter]: Factory method 'emailAuthenticationFilter' threw exception; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'authenticationManager' defined in class path resource [gg/leet/security/WebSecurityConfig.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.springframework.security.authentication.AuthenticationManager]: Factory method 'authenticationManager' threw exception; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'emailAuthenticationProvider': Unsatisfied dependency expressed through field 'userService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'userServiceImpl' defined in file [/Users/andrew/Programs/leet-tournaments/backend/build/classes/main/gg/leet/service/UserServiceImpl.class]: Unsatisfied dependency expressed through constructor parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userRepository': Cannot create inner bean '(inner bean)#76212c93' of type [org.springframework.orm.jpa.SharedEntityManagerCreator] while setting bean property 'entityManager'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name '(inner bean)#76212c93': Cannot resolve reference to bean 'entityManagerFactory' while setting constructor argument; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaAutoConfiguration.class]: Invocation of init method failed; nested exception is javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory
userServiceImpl
的参数 0 中的违规类是 userRepository
。
这是我的 UserRepository 的样子:
package gg.leet.repository;
import gg.leet.model.User;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;
import java.util.List;
import java.util.Optional;
@Repository
public interface UserRepository extends JpaRepository<User, Long> {
Optional<User> findByEmail(String email);
@Query("select u from User u where u.id = ?1")
Optional<User> findOneById(Long id);
User save(User user);
Optional<User> findOneByUsername(String username);
List<User> findByEmailContaining(String search);
List<User> findByFirstNameContaining(String search);
List<User> findByLastNameContaining(String search);
List<User> findByUsernameContaining(String search);
@Query("select u from User u where u.username like ?1 or u.firstName like ?1 or u.lastName like ?1")
Page<User> findByUsernameOrLastNameOrFirstNameContaining(String search, Pageable pageable);
}
用户服务实现:
package gg.leet.service;
import gg.leet.model.User;
import gg.leet.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.stereotype.Service;
import java.util.*;
/**
* Implementation of the UserService over the mysql repository
*/
@SuppressWarnings("unused")
@Service
public class UserServiceImpl implements UserService {
private final UserRepository userRepository;
@Autowired
public UserServiceImpl(UserRepository userRepository) {
this.userRepository = userRepository;
}
@Override
public Optional<User> getByUsername(String username) {
return this.userRepository.findOneByUsername(username);
}
@Override
public Optional<User> getByEmail(String email) { return this.userRepository.findByEmail(email); }
@Override
public Optional<User> getById(Long id) {
return this.userRepository.findOneById(id);
}
@Override
public User save(User user) {
return userRepository.save(user);
}
@Override
public Page<User> findByContaining(String search, Pageable pageable) {
return this.userRepository.findByUsernameOrLastNameOrFirstNameContaining(search, pageable);
}
}
没什么特别的,但我不明白为什么我们不能为身份验证过滤器实例化一个 bean。该错误有些笼统,所以我不知道应该在哪里寻找。我试图在配置类中手动初始化 entityManagerFactory
bean 并在 @EnableJpaRepositories
注释中引用它无济于事。关于我还应该在哪里解决此问题的任何建议?
----- 编辑 1 -----
这是我的数据源配置,相当小但在过去有效:
spring:
profiles: default
datasource:
url: jdbc:mysql://localhost:3306/leettournaments?autoReconnect=true&useSSL=false&useTimezone=true&serverTimezone=UTC
username: root
password:
jpa:
hibernate:
ddl-auto: create-drop
spring:
datasource:
driver-class-name: com.mysql.jdbc.Driver
max-active: 25
max-idle: 10
jpa:
hibernate:
dialect: org.hibernate.dialect.MySQLDialect
------ 编辑 2 ------
@SuppressWarnings("unused")
@Configuration
@EnableRedisHttpSession(maxInactiveIntervalInSeconds=Integer.MAX_VALUE, redisFlushMode=RedisFlushMode.IMMEDIATE)
@EnableWebSecurity
@EnableGlobalMethodSecurity(securedEnabled = true)
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
private static final Logger LOGGER = LogManager.getLogger(WebSecurityConfig.class);
@Value("${gg.leet.debug}")
private boolean debug;
/**
* Establishes role hierarchy for user roles.
* @return the RoleHierarchy
*/
@Bean
public RoleHierarchyImpl roleHierarchy() {
RoleHierarchyImpl roleHierarchy = new RoleHierarchyImpl();
roleHierarchy.setHierarchy(
"ROLE_SUPER_ADMIN > ROLE_LOCATION_ADMIN " +
"ROLE_LOCATION_ADMIN > ROLE_REGULAR_USER ");
return roleHierarchy;
}
@Bean
public RoleHierarchyVoter roleVoter() {
return new RoleHierarchyVoter(roleHierarchy());
}
@Bean
HeaderHttpSessionStrategy sessionStrategy() {
return new HeaderHttpSessionStrategy();
}
@Bean
public AuthenticationProvider emailAuthenticationProvider() {
return new EmailAuthenticationProvider();
}
@Bean
public AuthenticationManager authenticationManager() {
return new ProviderManager(Arrays.asList(
emailAuthenticationProvider()
));
}
@Bean
public AuthenticationSuccess authenticationSuccess() {
return new AuthenticationSuccess();
}
@Bean
public AuthenticationFailure authenticationFailure() {
return new AuthenticationFailure();
}
@Bean
public EmailAuthenticationFilter emailAuthenticationFilter() {
EmailAuthenticationFilter filter = new EmailAuthenticationFilter(new AntPathRequestMatcher("/login-process", "POST"));
applyFilterAuthRules(filter);
return filter;
}
private void applyFilterAuthRules(AbstractAuthenticationProcessingFilter filter) {
filter.setAuthenticationManager(authenticationManager());
filter.setAuthenticationSuccessHandler(authenticationSuccess());
filter.setAuthenticationFailureHandler(authenticationFailure());
filter.setAllowSessionCreation(true);
}
@Override
public void configure(WebSecurity web) throws Exception {
web
.ignoring()
.antMatchers("/", "/**/*.css", "/**/*.js", "/index.html", "/ws/**", "/assets/**/*");
}
@Override
protected void configure(HttpSecurity http) throws Exception {
if(debug) {
LOGGER.warn("Allowing preflight options requests to all");
// For the pre-flight request for options
http
.authorizeRequests()
.antMatchers(HttpMethod.OPTIONS, "/**")
.permitAll();
// Disable csrf on debug dev
LOGGER.warn("Allowing no CSRF protection");
http
.csrf()
.disable();
} else {
http
.csrf()
.csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse());
}
http
.authorizeRequests()
.antMatchers( "/**")
.permitAll()
.anyRequest()
.authenticated()
.and()
.logout()
.logoutUrl("/logout")
.logoutSuccessHandler((new HttpStatusReturningLogoutSuccessHandler(HttpStatus.OK)))
.invalidateHttpSession(true)
.permitAll()
.and()
.addFilterBefore(emailAuthenticationFilter(), FilterSecurityInterceptor.class);
http.requestCache().requestCache(new NullRequestCache());
http.headers().cacheControl();
http.headers().httpStrictTransportSecurity().disable();
// .headers().contentSecurityPolicy(
// .and().antMatcher("/bingo/card").;
}
@Bean
protected BCryptPasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
}
------ 编辑 3 ------
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'org.springframework.boot:spring-boot-gradle-plugin:1.4.3.RELEASE'
// classpath 'org.springframework:springloaded:1.2.6.RELEASE'
}
}
apply plugin: 'java'
apply plugin: 'idea'
apply plugin: 'org.springframework.boot'
apply plugin: 'io.spring.dependency-management'
repositories {
mavenCentral()
}
idea {
module {
inheritOutputDirs = false
outputDir = file("$buildDir/classes/main/")
}
}
jar {
baseName = 'leet-tournaments'
version = '0.1.0'
}
sourceCompatibility = 1.8
targetCompatibility = 1.8
configurations {
dev
all*.exclude module: 'spring-boot-starter-logging'
}
dependencies {
// Spring Boot Starter Framework
compile(
[group: 'org.springframework.boot', name: 'spring-boot-starter-data-jpa', version: '1.4.3.RELEASE'],
[group: 'org.springframework.boot', name: 'spring-boot-starter-log4j2', version: '1.2.0.RELEASE'],
[group: 'org.springframework.boot', name: 'spring-boot-starter-security', version: '1.4.3.RELEASE'],
[group: 'org.springframework.boot', name: 'spring-boot-starter-web', version: '1.3.2.RELEASE'],
[group: 'org.springframework.boot', name: 'spring-boot-starter-websocket', version: '1.0.0.RELEASE'],
[group: 'org.springframework.boot', name: 'spring-boot-starter-data-redis', version: '1.4.3.RELEASE'],
[group: 'org.springframework.boot', name: 'spring-boot-devtools', version: '1.4.3.RELEASE'],
[group: 'org.springframework.session', name: 'spring-session', version: '1.3.0.RELEASE'],
[group: 'org.springframework', name: 'spring-messaging', version: '4.3.6.RELEASE'],
)
compile(
[group: 'javax.mail', name: 'mail', version: '1.4.7'],
[group: 'com.fasterxml.jackson.core', name: 'jackson-core', version: '2.8.5'],
[group: 'mysql', name: 'mysql-connector-java', version: '5.1.35'],
[group: 'org.projectlombok', name: 'lombok', version: '1.16.12'],
[group: 'com.goebl', name: 'david-webb', version: '1.3.0'],
[group: 'com.amazonaws', name: 'aws-java-sdk', version: '1.11.77'],
[group: 'com.fasterxml.jackson.datatype', name: 'jackson-datatype-hibernate5', version: '2.8.8'],
[group: 'com.google.guava', name: 'guava', version: '22.0-rc1'],
)
compile(
[group: 'io.netty', name: 'netty-all', version: '4.1.7.Final'],
[group: 'io.projectreactor', name: 'reactor-core', version: '2.0.7.RELEASE'],
[group: 'io.projectreactor', name: 'reactor-net', version: '2.0.7.RELEASE'],
[group: 'io.projectreactor.spring', name: 'reactor-spring-core', version: '2.0.7.RELEASE'],
[group: 'io.projectreactor.spring', name: 'reactor-spring-context', version: '2.0.7.RELEASE'],
)
// testing
testCompile('org.springframework.boot:spring-boot-starter-test')
testCompile('junit:junit')
}
// gradle wrapper
task wrapper(type: Wrapper) {
gradleVersion = '3.0'
}
// run spring boot app
bootRun {
addResources = true
classpath = sourceSets.main.runtimeClasspath + configurations.dev
}
主类:
@SpringBootApplication
@EnableConfigurationProperties
@EnableAutoConfiguration
@EnableScheduling
@ComponentScan
public class LeetTournaments {
private static final Logger LOGGER = LogManager.getLogger(LeetTournaments.class);
public static void main(String[] args) {
SpringApplication.run(LeetTournaments.class, args);
// LeetTournaments.initDB();
}
static void initDB() {
Webb webb = Webb.create();
webb.get("http://127.0.0.1:8080/init").asString();
}
}
最佳答案
请注意标有粗体的文字:
Spring Data repositories usually extend from the
Repository
orCrudRepository
interfaces. If you are using auto-configuration, repositories will be searched from the package containing your main configuration class (the one annotated with@EnableAutoConfiguration
or@SpringBootApplication
) down.— Spring Boot Reference Guide, 29.3.2 Spring Data JPA Repositories.
其实,我认为这是解决问题的方法(粗体标出的文字):
By default, Spring Boot will enable JPA repository support and look in the package (and its subpackages) where
@SpringBootApplication
is located. If your configuration has JPA repository interface definitions located in a package not visible, you can point out alternate packages using@EnableJpaRepositories
and its type-safebasePackageClasses=MyRepository.class
parameter.
总而言之,考虑如下更新 LeetTournaments
类的实现:
@EnableJpaRepositories(basePackageClasses = UserRepository.class)
public class LeetTournaments {
...
}
希望这对您有所帮助。
关于java - Spring Boot JPA Starter 的 Spring Boot 启动问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45611767/
有什么区别: spring-boot-starter-web spring-boot-starter-web-services spring-boot-starter-jersey? 文档说 Star
我注意到 Spring Boot Sample Data Redis 声明了以下依赖项: org.springframework.boot spring-boot-starter
我正在观看有关 Spring Boot 的视频教程(来自 javabrains.io)。示例项目的 pom 文件包含一个父 block ,其 groupId 为 org.springframework
我正在努力尝试使用 spring boot (1.1.6.RELEASE)、gradle (2.1) 和 Java 1.8 来练习一些技术。所以我们正在考虑支持一些旧式 SOAP Web 服务调用以及
我正在尝试学习 Spring Boot,但我注意到有两种选择。 spring-boot-starter-web - 根据文档,它支持全栈 Web 开发,包括 Tomcat 和 web-mvc spri
我正在尝试在 IntellIJ 中开发一个基于 Spring Boot 的示例应用程序。所以我使用了 spring Initialzr 方法,并在设置过程中进行了默认选择。我最终得到的 pom.xml
是否可以在一个应用程序中同时使用这两个启动器? 我想将 CSV 文件中的记录加载到数据库表中。 Spring Batch 表存储在不同的数据库中,因此我假设我需要使用 JTA 来处理事务。 每当我将
我有一个微服务应用程序,在我包含的 JAR 依赖项之一中 org.springframework.boot spring-boot-starter-webflux 所以我可以使用响
当我开始学习spring-webflux时,我对这个组件有疑问。 我构建了一个简单的项目,使用maven来管理它。我添加了与 spring-boot-starter-web 和 spring-boot
我已经使用 optaplanner-spring-boot-starter 作为依赖项开发了一个完整的工作 spring boot 项目,用于任务分配,但要求是使用 kie-server-spring
当我开始学习spring-webflux时,我对这个组件有疑问。 我构建了一个简单的项目,使用 maven 来管理它。我添加了与 spring-boot-starter-web 和 spring-bo
我尝试了 spring-boot-starter-actuator,默认指令,在 pom 中添加到 spring boot 项目,它运行没有任何问题。 一旦我添加 spring-boot-starte
我当时尝试包含上述依赖项之一,但找不到任何区别: spring boot starter web:我可以看到 Flux 和 Mono 类并制作一个响应式(Reactive)休息 Controller
我们将 spring-cloud-starter-hystrix 与 spring-cloud-starter-archaius 一起使用,一旦 war 取消部署,我们将无法停止 archaius 的
我刚刚开始使用 OAuth2 学习 Spring Security,我想为我的微服务 Restful Api 创建授权服务器和资源服务器。但是我不知道从哪个依赖项开始,因为我找到了其中的一些。我使用
我正在使用 spring-boot-starter-jersey 和 spring-boot-starter-tomcat (v. 1.5.2) 和作为因此,我宁愿不添加 spring-boot-st
我正在尝试对微服务的端点实现基本身份验证。所以我使用了 spring-boot-starter-security。但我注意到 spring-boot-starter-security 不适用于 spr
我想使用 spring-boot-starter,但这意味着我必须使用“spring-boot-starter-parent”pom 而不能使用公司广泛使用的根 pom。 Spring-boot-st
目前我们正在使用 com.graphql-java-kickstart graphql-spring-boot-starter ${graph
我是 Spring Cloud 的新手,两者之间的确切区别是什么spring-cloud-starter-eureka-server和 spring-cloud-starter-netflix-eur
我是一名优秀的程序员,十分优秀!