代码之家  ›  专栏  ›  技术社区  ›  Ke Vin

为什么我在springboot中收到工厂方法“halLinkDiscoverer”抛出异常的错误?

  •  1
  • Ke Vin  · 技术社区  · 5 年前

    嗨,我是springboot的新手,我试图用它创建RESTful API,当我用它创建控制器时,它已经工作了,但当我试图在pom.xml中添加这行时

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-rest</artifactId>
    </dependency>
    

    当我尝试使用以下命令运行应用程序时,它会给我带来错误 java -jar target/gs-accessing-mongodb-data-rest-0.1.0.jar

    org.springframework.beans.factory。BeanCreationException:创建名为“halLinkDiscoverer”的bean时出错,该bean在类路径资源[org/springframework/heateoas/mediatype/hal/HalMediaTypeConfiguration.class]中定义:通过工厂方法实例化bean失败;嵌套异常是org.springframework.beans。BeanInstance异常:未能实例化[org.springframework.heatoas.client.LinkDiscoverer]:工厂方法“halLinkDiscoverer”抛出异常;嵌套异常是java.lang.NoClassDefFoundError:com/jayway/jsonpath/PathNotFoundException 请访问org.springframework.beans.factory.support。构造函数解析器实例化(构造函数解析器.java:656)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。构造函数解析器.instanitate使用FactoryMethod(构造函数解析器.java:484)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。AbstractAutowireCapableBeanFactory.institute使用Factory方法(AbstractAutowireCapableBeanFactory.java:1338)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。AbstractAutowireCapableBeanFactory.createBeanInstance(抽象AutowirecapableBeanFactory.java:1177)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。AbstractAutowireCapableBeanFactory.doCreateBean(抽象AutowirecapableBeanFactory.java:557)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。AbstractAutowireCapableBeanFactory.createBean(抽象AutowirecapableBeanFactory.java:517)~[spring-beans-5.2.3.发布.jar!/:5.2.3.发布] 请访问org.springframework.beans.factory.support。AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:323)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。DefaultSingletonBeanRegister.getSingleton(默认SingletonBeanRegistry.java:222)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:321)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。AbstractBeanFactory.getBean(AbstractBeanFactory.java:202)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。默认列表BeanFactory.preInstantiateSingletons(默认列表BeanFactory.java:879)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.context.support。AbstractApplicationContext.finishBeanFactory初始化(抽象应用上下文.java:878)~[spring-context-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.context.support。AbstractApplicationContext.refresh(AbstractApplicationContext.java:550)~[spring-context-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.boot.web.servlet.context。ServletWebServerApplicationContext.refresh(ServletWebServer ApplicationContext.java:141)~[spring-boot-2.2.3.RELEASE.jar!/:2.2.3.RELEASE] 在org.springframework.boot上。SpringApplication.refresh(SpringApplication.java:747)~[spring-boot-2.2.3.RELEASE.jar!/:2.2.3.RELEASE] 在org.springframework.boot上。SpringApplication.refreshContext(SpringApplication.java:397)~[spring-boot-2.2.3.RELEASE.jar!/:2.2.3.RELEASE] 在org.springframework.boot上。SpringApplication.run(SpringApplication.java:315)~[spring-boot-2.2.3.RELEASE.jar!/:2.2.3.RELEASE] 在org.springframework.boot上。SpringApplication.run(SpringApplication.java:1226)~[spring-boot-2.2.3.RELEASE.jar!/:2.2.3.RELEASE] 在org.springframework.boot上。SpringApplication.run(SpringApplication.java:1215)~[spring-boot-2.2.3.RELEASE.jar!/:2.2.3.RELEASE] 在com.movie.db上。KotakKantorMovieDB。KotakKantorMovieDbApplication.main(KotakKantor MovieDbApplication.java:10)~[类!/:0.0.1-SNAPSHOT] 在java.base/jdk.international.reflect上。NativeMethodAccessorImpl.invoke0(本机方法)~[na:na] 在java.base/jdk.international.reflect上。NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)~[na:na] 在java.base/jdk.international.reflect上。删除MethodAccessorImpl.invoke(删除MethodAccessor Impl.java:43)~[na:na] 在java.base/java.lang.reflect上。方法调用(方法.java:567)~[na:na] 在org.springframework.boot.loader上。MainMethodRunner.run(MainMethodRunner.java:48)~[KotakKantorMovieDB--0.01-SNAPSHOT.jar:0.0.1-SNAPSHOT] 在org.springframework.boot.loader上。Launcher.launch(Launcher.java:87)~[KotakKantorMovieDB--0.01-SNAPSHOT.jar:0.0.1-SNAPSHOT] 在org.springframework.boot.loader上。Launcher.launch(Launcher.java:51)~[KotakKantorMovieDB--0.01-SNAPSHOT.jar:0.0.1-SNAPSHOT] 在org.springframework.boot.loader上。JarLauncher.main(JarLauncher.java:52)~[KotakKantorMovieDB--0.01-SNAPSHOT.jar:0.0.1-SNAPSHOT] 原因:org.springframework.beans。BeanInstance异常:未能实例化[org.springframework.heatoas.client.LinkDiscoverer]:工厂方法“halLinkDiscoverer”抛出异常;嵌套异常是java.lang.NoClassDefFoundError:com/jayway/jsonpath/PathNotFoundException 请访问org.springframework.beans.factory.support。SimpleInstantitionStrategy.institute(SimpleInstantiationStrategy.java:185)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 请访问org.springframework.beans.factory.support。构造函数解析器实例化(构造函数解析器.java:651)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] …省略了27个常见帧 原因:java.lang.NoClassDefFound错误:com/jayway/jsonpath/PathNotFoundException 在org.springframework.hateoas.mediatype.hal上。HalMediaTypeConfiguration.halLinkDiscoverer(HalMediaTypeConfig.java:65)~[spring-hateoas-1.0.3.RELEASE.jar!/:1.0.3.RELEASE] 在org.springframework.hateoas.mediatype.hal上。HalMediaType配置$$EnhancedrBySpringCGLIB$$a3e51c0b。CGLIB$halLinkDiscoverer$2()~[spring-hateoas-1.0.3.发布.jar!/:1.0.3.发布] 在org.springframework.hateoas.mediatype.hal上。HalMediaType配置$$EnhancedrBySpringCGLIB$$a3e51c0b$$$FastClassBySpringCGLIB$$bb4bacfd.invoke()~[spring-hateoas-1.0.3.RELEASE.jar!/:1.0.3.RELEASE] 请访问org.springframework.cglib.proxy。MethodProxy.invokeSuper(MethodProxy.java:244)~[spring-core-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 在org.springframework.context.annotation上。ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnenhancer.java:363)~[spring-context-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] 在org.springframework.hateoas.mediatype.hal上。HalMediaType配置$$EnhancedrBySpringCGLIB$$a3e51c0b.halLinkDiscoverer()~[spring-has-1.0.3.RELEASE.jar!/:1.0.3.RELEASE] 在java.base/jdk.international.reflect上。NativeMethodAccessorImpl.invoke0(本机方法)~[na:na] 在java.base/jdk.international.reflect上。NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)~[na:na] 在java.base/jdk.international.reflect上。删除MethodAccessorImpl.invoke(删除MethodAccessor Impl.java:43)~[na:na] 在java.base/java.lang.reflect上。方法调用(方法.java:567)~[na:na] 请访问org.springframework.beans.factory.support。SimpleInstantitionStrategy.institute(SimpleInstantiationStrategy.java:154)~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE] …省略了28个常见帧 原因:java.lang.ClassNotFoundException:com.jayway.jsonpath。PathNotFound异常 在java.base/java.net上。URLClassLoader.findClass(URLClassLoader.java:436)~[na:na] 在java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:588)~[na:na] 在org.springframework.boot.loader上。已启动URLClassLoader.loadClass(已启动URLclassLoader.java:92)~[KotakKantorMovieDB--0.01-SNAPSHOT.jar:0.0.1-SNAPSHOT] 在java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521)~[na:na]

    我没有对它做任何事情,当我只是添加依赖关系时,我的应用程序会给我这个错误。这是我的完整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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.2.3.RELEASE</version>
            <relativePath/>
            <!-- lookup parent from repository -->
        </parent>
        <groupId>com.movie.db</groupId>
        <artifactId>KotakKantorMovieDB</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>KotakKantorMovieDB</name>
        <description>Demo project for Spring Boot</description>
    
        <properties>
            <java.version>13</java.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-rest</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
                <exclusions>
                    <exclusion>
                        <groupId>org.junit.vintage</groupId>
                        <artifactId>junit-vintage-engine</artifactId>
                    </exclusion>
                </exclusions>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-devtools</artifactId>
                <optional>true</optional>
            </dependency>
    
            <dependency>
                <groupId>com.jayway.jsonpath</groupId>
                <artifactId>json-path</artifactId>
                <scope>test</scope>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-mongodb</artifactId>
            </dependency>
    
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    
    </project>
    

    这是我的控制器:

    package com.movie.db.KotakKantorMovieDB.controllers;
    
    import com.movie.db.KotakKantorMovieDB.models.Customer;
    import com.movie.db.KotakKantorMovieDB.repository.CustomerRepository;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.*;
    
    @RestController
    public class CustomerController {
    
      @Autowired
      private CustomerRepository repository;
    
      @GetMapping("/customer")
      public Customer findCustomer() {
        return repository.findByFirstName("cactuspot");
      }
    
      @PostMapping("/addcustomer")
      public Customer addCustomer(@RequestBody Customer newCustomer ) {
        return repository.save(newCustomer);
      }
    
    }
    

    这是我的模型:

    package com.movie.db.KotakKantorMovieDB.models;
    
    import org.springframework.data.annotation.Id;
    
    public class Customer {
        @Id
        public String id;
    
        public String firstName;
        public String lastName;
    
        public String getFirstName() {
            return firstName;
        }
    
        public void setFirstName(String firstName) {
            this.firstName = firstName;
        }
    
        public String getLastName() {
            return lastName;
        }
    
        public void setLastName(String lastName) {
            this.lastName = lastName;
        }
    
    }
    

    这是我的仓库:

    package com.movie.db.KotakKantorMovieDB.repository;
    
    import java.util.List;
    
    import com.movie.db.KotakKantorMovieDB.models.Customer;
    
    import org.springframework.data.mongodb.repository.MongoRepository;
    
    public interface CustomerRepository extends MongoRepository<Customer, String> {
    
        public Customer findByFirstName(String firstName);
        public List<Customer> findByLastName(String lastName);
    
    }
    

    我错过了什么?我是否有一些不应该使用的依赖关系,我添加了whtn spring-boot-starter-data-rest ?

    0 回复  |  直到 5 年前
        1
  •  10
  •   Ke Vin    5 年前

    我试图删除:

    <dependency>
                <groupId>com.jayway.jsonpath</groupId>
                <artifactId>json-path</artifactId>
                <scope>test</scope>
    </dependency>
    

    这个依赖关系解决了错误,我不知道为什么这个依赖关系会导致错误,也不知道为什么需要这个依赖关系,我运行我的应用程序,没有这个依赖关系它就可以正常工作。也许这与HATEOAS有关。如果有人能向我解释,我会接受它作为答案

        2
  •  4
  •   newbNox    4 年前

    那些仍然面临测试范围问题的人会删除测试范围。在pom.xml中添加此依赖项即可。

    <dependency>
        <groupId>com.jayway.jsonpath</groupId>
        <artifactId>json-path</artifactId>
    </dependency>
    
        3
  •  1
  •   puntodamar    4 年前

    我来自乌代米。 我也犯了同样的错误,作者建议替换

    <dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-rest-hal-browser</artifactId>
    <version>3.3.6.RELEASE</version>
    </dependency>
    

    具有

    <dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-rest-hal-explorer</artifactId>
    </dependency>
    

    这对我来说是有效的。

        4
  •  0
  •   Goodwin Antony    3 年前

    我发现错误在这个测试依赖关系的作用域标签中

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

    删除范围标签并添加如下内容

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

    然后,它对我奏效了,没有任何其他变化

    谢谢