Otrzymuję poniższy wyjątek podczas uruchamiania aplikacji rozruchu sprężynowego podczas uruchamiania:
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'testController': Injection of autowired dependencies failed; nested exception is org.springframework.beans.factory.BeanCreationException: Could not autowire field: private org.springframework.web.client.RestTemplate com.micro.test.controller.TestController.restTemplate; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [org.springframework.web.client.RestTemplate] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
Jestem autowiring RestTemplate w moim TestController. Używam Mavena do zarządzania zależnościami.
TestMicroServiceApplication.java
package com.micro.test;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class TestMicroServiceApplication {
public static void main(String[] args) {
SpringApplication.run(TestMicroServiceApplication.class, args);
}
}
TestController.java
package com.micro.test.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
@RestController
public class TestController {
@Autowired
private RestTemplate restTemplate;
@RequestMapping(value="/micro/order/{id}",
method=RequestMethod.GET,
produces=MediaType.ALL_VALUE)
public String placeOrder(@PathVariable("id") int customerId){
System.out.println("Hit ===> PlaceOrder");
Object[] customerJson = restTemplate.getForObject("http://localhost:8080/micro/customers", Object[].class);
System.out.println(customerJson.toString());
return "false";
}
}
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.micro.test</groupId>
<artifactId>Test-MicroService</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>Test-MicroService</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>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>
spring
maven
spring-boot
resttemplate
Khuzi
źródło
źródło
RestTemplate
nie jest automatycznie tworzone dla ciebie.Odpowiedzi:
Dokładnie to mówi błąd. Nie stworzyłeś żadnej
RestTemplate
fasoli, więc nie może ona automatycznie podłączać. Jeśli potrzebujeszRestTemplate
, musisz go zapewnić. Na przykład dodaj następujący kod do TestMicroServiceApplication.java :Uwaga, we wcześniejszych wersjach Spring Cloud Starter dla Eureki stworzono
RestTemplate
fasolę, ale to już nie prawda.źródło
RestTemplate
kiedy wszystko inne jest magicznie utworzone i połączone. Zwłaszcza jeśli wcześniej używano wiosennej chmury, która zapewnia autokonfiguracjęRestTemplate
. ;-)RestTemplateBuilder
można używać do zarządzaniaRestTemplate
instancjami. Przykład tutaj spring.io/guides/gs/consuming-restspring-cloud-netflix
artefaktydu z wersją1.1.5.RELEASE
. Mój RestTemplate jest wywoływany z@RestController
klasy Java, która używa@Autowired
dlaRestTemplate
. Czy ktoś może pomóc?W zależności od tego, jakich technologii używasz i jakie wersje będą miały wpływ na to, jak zdefiniujesz
RestTemplate
w swojej@Configuration
klasie.Wiosna> = 4 bez butów sprężynowych
Po prostu zdefiniuj
@Bean
:Spring Boot <= 1.3
Nie musisz go definiować, Spring Boot automatycznie definiuje go za Ciebie.
Spring Boot> = 1.4
Spring Boot nie definiuje już automatycznie a,
RestTemplate
ale zamiast tego definiuje,RestTemplateBuilder
co pozwala na większą kontrolę nad tworzonym RestTemplate. Możesz wstrzyknąćRestTemplateBuilder
argument jako argument w swojej@Bean
metodzie, aby utworzyćRestTemplate
:Używanie go w klasie
Odniesienie
źródło
Jeśli TestRestTemplate jest prawidłową opcją w teście jednostkowym, ta dokumentacja może być odpowiednia
http://docs.spring.io/spring-boot/docs/1.4.1.RELEASE/reference/htmlsingle/#boot-features-rest-templates-test-utility
Krótka odpowiedź: jeśli używasz
wtedy
@Autowired
zadziała. Jeśli używasznastępnie utwórz TestRestTemplate w ten sposób
źródło
Błąd wskazuje bezpośrednio, że
RestTemplate
fasola nie jest zdefiniowana w kontekście i nie może jej załadować.Jeśli masz pewność, że ziarno jest zdefiniowane dla RestTemplate, użyj poniższego, aby wydrukować ziarna dostępne w kontekście załadowanym przez aplikację rozruchową sprężyny
Jeśli zawiera ziarno o podanej nazwie / typie, wszystko jest w porządku. Albo zdefiniuj nową fasolę i użyj jej.
źródło
RestTemplateBuilder oferuje właściwy sposób konfigurowania i tworzenia instancji komponentu bean szablonu reszty, na przykład dla podstawowego uwierzytelniania lub przechwytywaczy.
źródło
@Bean public RestTemplate restTemplate(RestTemplateBuilder builder){ return builder.build(); }
źródło
Upewnij się, że dwie rzeczy:
1- Użyj
@Bean
adnotacji z metodą.2- Zakres tej metody powinien być publiczny, a nie prywatny .
Kompletny przykład -
źródło
W najprostszy sposób udało mi się osiągnąć podobny wyczyn, używając poniższego kodu ( odniesienie ), ale radziłbym nie wykonywać wywołań API w kontrolerach ( zasady SOLID ). Również autoprzewodowanie w ten sposób jest lepiej zoptymalizowane niż tradycyjny sposób.
źródło
próbujesz wstrzyknąć restTemplate, ale musisz utworzyć klasę konfiguracji. wtedy musisz utworzyć fasolę, która zwróci ci nowy RestTemplate, patrz poniższy przykład.
źródło