Spring lemon BeanCurrentlyInCreationException:创建bean时出错

时间:2016-05-02 19:36:41

标签: java spring spring-mvc spring-boot spring-lemon

我正在尝试按照这个春季 - 柠檬入门教程(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>

1 个答案:

答案 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存储库的修复程序。