我正在尝试按照这个春季 - 柠檬入门教程(https://naturalprogrammer.gitbooks.io/spring-lemon-getting-started/content/index.html),但我不能在某一点上走得更远。 我创建了一个新的Spring启动项目(Spring boot),我能够添加spring lemon。我没有做任何事情,只是遵循说明,但当我开始maven构建时,测试失败并出现以下错误:
org.springframework.beans.factory.BeanCreationException:错误 创建名为'lmnDemoController'的bean:注入自动装配 依赖失败;嵌套异常是 org.springframework.beans.factory.BeanCreationException:不能 autowire方法:public void com.naturalprogrammer.spring.lemon.LemonController.setLemonService(com.naturalprogrammer.spring.lemon.LemonService); 嵌套异常是 org.springframework.beans.factory.BeanCurrentlyInCreationException: 创建名为'lmnDemoService'的bean时出错:名称为Bean 'lmnDemoService'已经注入其他bean [authenticationSuccessHandler]在其原始版本中作为一部分 循环引用,但最终被包裹。这意味着 说其他bean不使用bean的最终版本。这是 通常是过度渴望类型匹配的结果 - 考虑使用 'getBeanNamesOfType'与'allowEagerInit'标志关闭,for 示例
我的LmnDemoService.java
是:
package com.example;
import org.springframework.stereotype.Service;
import com.naturalprogrammer.spring.lemon.LemonService;
@Service
public class LmnDemoService extends LemonService<User, Long> {
@Override
protected User newUser() {
return new User();
}
}
除了教程所说的内容之外别无其他。我错过了什么?
编辑:
LmndemoApplication.java
package com.example;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import com.naturalprogrammer.spring.lemon.LemonConfig;
@SpringBootApplication(scanBasePackageClasses = {LmndemoApplication.class, LemonConfig.class})
public class LmndemoApplication {
public static void main(String[] args) {
SpringApplication.run(LmndemoApplication.class, args);
}
}
LmnDemoController.java
package com.example;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.naturalprogrammer.spring.lemon.LemonController;
@RestController
@RequestMapping("/api/core")
public class LmnDemoController extends LemonController<User, Long> {
}
LmnDemoService.java
package com.example;
import org.springframework.stereotype.Service;
import com.naturalprogrammer.spring.lemon.LemonService;
@Service
public class LmnDemoService extends LemonService<User, Long> {
@Override
protected User newUser() {
return new User();
}
}
SecurityConfig.java
package com.example;
import org.springframework.context.annotation.Configuration;
import com.naturalprogrammer.spring.lemon.security.LemonSecurityConfig;
@Configuration
public class SecurityConfig extends LemonSecurityConfig {
}
ServletInitializer.java
package com.example;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.context.web.SpringBootServletInitializer;
public class ServletInitializer extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(LmndemoApplication.class);
}
}
User.java
package com.example;
import javax.persistence.Entity;
import javax.persistence.Table;
import com.naturalprogrammer.spring.lemon.domain.AbstractUser;
@Entity
@Table(name="usr")
public class User extends AbstractUser<User,Long> {
private static final long serialVersionUID = 2716710947175132319L;
}
UserRepository.java
package com.example;
import com.naturalprogrammer.spring.lemon.domain.AbstractUserRepository;
public interface UserRepository extends AbstractUserRepository<User, Long> {
}
application.properties
#Database configuration
spring.jpa.database: MYSQL
spring.jpa.hibernate.ddl-auto: update
spring.datasource.url: jdbc:mysql://localhost:3306/mydatabase
spring.datasource.username: myuser
spring.datasource.password: mypassword
#DevTools configuration
spring.devtools.livereload.enabled: false
spring.devtools.restart.enabled: false
#Application URL
#lemon.application-url: http://localhost:9000
#reCAPTCHA configuration
#lemon.recaptcha.sitekey: your google recaptcha site key
#lemon.recaptcha.secretkey: your google recaptcha secret key
#Remember me configuration
#lemon.remember-me-key: someSecret
#First administrator
lemon.admin.username: admin@example.com
lemon.admin.password: admin
#Email configuration
#spring.mail.host = smtp.gmail.com
#spring.mail.username = xxxxxx@gmail.com
#spring.mail.password = xxxxxx
#
#spring.mail.properties.mail.smtp.auth = true
#spring.mail.properties.mail.smtp.socketFactory.port = 465
#spring.mail.properties.mail.smtp.socketFactory.class = javax.net.ssl.SSLSocketFactory
#spring.mail.properties.mail.smtp.socketFactory.fallback = false
#spring.mail.properties.mail.smtp.ssl.enable = true
#Handling cross origin requests configuration
#lemon.cors.allowed-origins: http://localhost:9000
#This will disable the protection against JSON vulnerability
#lemon.enabled.json-prefix: false
pom.xml
http://maven.apache.org/xsd/maven-4.0.0.xsd"> 4.0.0
<groupId>com.example</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>lmndemo</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- Spring-lemon -->
<dependency>
<groupId>com.naturalprogrammer.spring</groupId>
<artifactId>spring-lemon</artifactId>
<version>0.8.5</version><!-- See https://github.com/naturalprogrammer/spring-lemon/releases for latest release -->
</dependency>
</dependencies>
<build>
<finalName>lmndemo</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
答案 0 :(得分:2)
在我看来就像一个循环引用问题。它并没有发生在我的环境中,我认为Spring应该能够自己解决它,但最好是修复Spring Lemon代码以使其更强大,我认为。
那么,您可以尝试在工作区中签出的Spring Lemon代码中@Lazy
类的setLemonService
方法上添加AuthenticationSuccessHandler
注释吗?看起来如下:
@Autowired
@Lazy // add this line
public void setLemonService(LemonService<?, ?> lemonService) {
this.lemonService = lemonService;
}
我之前没有尝试@Lazy
,但我认为它应该有效。如果没有,我们需要考虑另一种方法来打破循环依赖。
让我知道。找到解决方案后,我将检查Spring Lemon存储库的修复程序。