【问题标题】:could not found bean for MongoRepository (Spring Boot)找不到 MongoRepository (Spring Boot) 的 bean
【发布时间】:2017-12-13 20:19:24
【问题描述】:

我正在使用spring bootMongoDB

Spring version : 4.3.9

Spring boot version : 1.5.4

我正在创建一个实现 MongoRepository interface 的存储库,如下所示

import org.springframework.data.mongodb.repository.MongoRepository;
import org.springframework.stereotype.Repository;

@Repository
public interface HotelRepository extends MongoRepository<Hotel,String> {
}

但是,每当我向 HotelRepository 编译器添加依赖项时,都会出现错误Field hotelRepository in com.demo.HotelController required a bean of type 'com.demo.HotelRepository' that could not be found.

@RestController
@RequestMapping("/hotel")
public class HotelController {

    @Autowired
    private HotelRepository hotelRepository;

    @GetMapping("/all")
    public List<Hotel> getAllHotels(){
        return this.hotelRepository.findAll();
    }
}

我已经从我的角度检查了所有方面以解决错误,但都是徒劳的。我研发的东西。

  • 对于HotelRepository,将提供开箱即用的默认实现。 as per spring docs
  • 我已经用@Repository注释了接口,所以不需要放@Component
  • 使用@Autowired注解从spring上下文添加依赖,所以它应该从spring上下文中选择创建的bean。
  • 所有需要的文件都在同一个包里,所以不用放@ComponentScan

这是我的主要 Spring Boot 应用程序类:

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class MongoWithBootApplication {

    public static void main(String[] args) {
        SpringApplication.run(MongoWithBootApplication.class, args);
    }
}

application.properties:

spring.data.mongodb.host=localhost
spring.data.mongodb.port=27017
spring.data.mongodb.database=HotelDB

堆栈跟踪

2017-07-10 13:25:12.485  INFO 4712 --- [           main] com.demo.MongoWithBootApplication        : Starting MongoWithBootApplication on KELLGGNCPU0313 with PID 4712 (D:\STS_WS\MongoWithBoot\target\classes started by mehrajuddin.malik in D:\STS_WS\MongoWithBoot)
2017-07-10 13:25:12.487  INFO 4712 --- [           main] com.demo.MongoWithBootApplication        : No active profile set, falling back to default profiles: default
2017-07-10 13:25:12.519  INFO 4712 --- [           main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@13acb0d1: startup date [Mon Jul 10 13:25:12 IST 2017]; root of context hierarchy
2017-07-10 13:25:13.448  INFO 4712 --- [           main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port(s): 8080 (http)
2017-07-10 13:25:13.456  INFO 4712 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2017-07-10 13:25:13.456  INFO 4712 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet Engine: Apache Tomcat/8.5.15
2017-07-10 13:25:13.541  INFO 4712 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2017-07-10 13:25:13.541  INFO 4712 --- [ost-startStop-1] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 1025 ms
2017-07-10 13:25:13.635  INFO 4712 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean  : Mapping servlet: 'dispatcherServlet' to [/]
2017-07-10 13:25:13.637  INFO 4712 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'characterEncodingFilter' to: [/*]
2017-07-10 13:25:13.638  INFO 4712 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
2017-07-10 13:25:13.638  INFO 4712 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'httpPutFormContentFilter' to: [/*]
2017-07-10 13:25:13.638  INFO 4712 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'requestContextFilter' to: [/*]
2017-07-10 13:25:13.673  WARN 4712 --- [           main] ationConfigEmbeddedWebApplicationContext : Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'hotelController': Unsatisfied dependency expressed through field 'hotelRepository'; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'com.demo.HotelRepository' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
2017-07-10 13:25:13.675  INFO 4712 --- [           main] o.apache.catalina.core.StandardService   : Stopping service [Tomcat]
2017-07-10 13:25:13.684  INFO 4712 --- [           main] utoConfigurationReportLoggingInitializer : 

Error starting ApplicationContext. To display the auto-configuration report re-run your application with 'debug' enabled.
2017-07-10 13:25:13.737 ERROR 4712 --- [           main] o.s.b.d.LoggingFailureAnalysisReporter   : 

***************************
APPLICATION FAILED TO START
***************************

Description:

Field hotelRepository in com.demo.HotelController required a bean of type 'com.demo.HotelRepository' that could not be found.


Action:

Consider defining a bean of type 'com.demo.HotelRepository' in your configuration.

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.demo</groupId>
    <artifactId>MongoWithBoot</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>MongoWithBoot</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.4.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>


</project>

有人可以帮我看看我错过了什么吗?

【问题讨论】:

  • 请分享您的源代码应用程序类。
  • 在您的配置中添加 @EnableMongoRepositories(basePackages = "your.repository.package") 注释
  • 你也可以发布详细的堆栈跟踪吗?
  • @StanislavL 我没有使用任何基于 Java 的配置,只是使用 application.properties
  • @JaydeepRajput 我已经添加了堆栈跟踪。

标签: java spring mongodb spring-boot dependency-injection


【解决方案1】:

我有相同的结构,我只需要添加这个配置:

Application.java

@Configuration
@SpringBootApplication
public class Application extends SpringBootServletInitializer {
    ...
}

application.properties

spring.data.mongodb.uri=mongodb://localhost:27017/hotelDB

并且存储库包必须在更深层次的 Application.java 类中。就这些

com.hotelDB
    Application.java
    repository (Package)
    controller (Package)
    service (Package)
    ...

【讨论】:

    【解决方案2】:

    经过这么多的努力,我终于解决了这个问题。

    代码或注释没有错。 问题出在 Spring Boot 的版本上

    但是,我仍然不确定1.5.1.RELEASE 以上版本有什么问题。如果有人知道根本原因,可以编辑或回答问题。

    问题:如果我在1.5.1.RELEASE 上方添加spring-boot-starter-parent,它会给我上面MongoRepository 的no bean 错误。它给出了从1.5.21.5.4 版本的错误。 (1.5.4 是我尝试并面临无 bean 错误之前的最后一个版本)

    解决方案:如果我添加spring-boot-starter-parent 1.5.1.RELEASE 或以下(1.5.0 是我尝试过的最低版本),它运行良好。

    【讨论】:

      【解决方案3】:

      刚刚使用1.5.4.RELEASE for spring-boot-starter-parent 尝试了我现有的spring boot mongodb项目并没有发现任何问题。

      之前它被配置为1.4.0.RELEASE

      【讨论】:

        【解决方案4】:

        我们需要使用 EnableMongoRepositories 激活 mongo 存储库

        @SpringBootApplication
        @EnableMongoRepositories //specify packages to scan
        public class MongoWithBootApplication{ ... }
        

        【讨论】:

        • 谢谢。它解决了 spring boot 1.4.1-RELEASE 的问题。
        【解决方案5】:

        遇到类似问题,将以下内容添加到 Application 类帮助我解决了问题

        @EnableMongoRepositories(basePackageClasses = DeviceDataRepository.class)
        

        在你的情况下它可能是

        @SpringBootApplication
        @EnableMongoRepositories(basePackageClasses = HotelRepository.class)
        public class MongoWithBootApplication{ ... }
        

        【讨论】:

          【解决方案6】:

          我遇到了同样的问题

          使用下面的代码来扫描 mongorepository 包

          @SpringBootApplication                                                       
          @EnableMongoRepositories(basePackages = {"//packages you want to scan for activiting mongo repositories"})
          public class SpringBootMongoDBApp{ ... }
          

          解决了我的问题

          【讨论】:

            猜你喜欢
            • 1970-01-01
            • 2022-11-10
            • 2018-12-13
            • 2018-10-01
            • 1970-01-01
            • 2019-07-16
            • 2017-11-05
            • 1970-01-01
            • 2018-06-12
            相关资源
            最近更新 更多