webentwicklung-frage-antwort-db.com.de

REST Client restTemplate kann keine Sammlung von Objekten abrufen

Ich benutze Spring restTemplate. Ich habe einen REST - Dienst und einen Client als Komponententest in einer separaten Anwendung erstellt. Ich habe eine Methode, die eine Liste der Benutzer und eine Methode für die Benutzererstellung zurückgibt:

@GET
@Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON,
        MediaType.TEXT_XML })
@Path("/all")
public Response getAllUsers() {
    List<User> list = dao.getAll();
    GenericEntity<List<User>> result = new GenericEntity<List<User>>(list) {
    };
    return Response.status(Status.OK).entity(result).build();
}

Wenn ich alle Benutzer im Browser anzeigen möchte, wird mir XML angezeigt. Es ist in Ordnung. Aber wenn ich versuche, dies zu verwenden:

@Test
public void testGetAll() {
    List list = new RestTemplate().getForObject(URL + "all", List.class);
    System.out.println(list);
}

Ich habe

WARNING: GET request for "http://localhost:8080/REST/all" resulted in 500 (Internal Server Error); invoking error handler

Ich habe versucht, das zu debuggen. Keine Ausnahmen bei Methodenarbeiten. Und der Browser zeigt mir die XML-Datei mit den Benutzern ... Was kann falsch sein? 

Ich möchte auch wissen, wie ich Statuscode oder Nachricht von einem Vorlagenobjekt (zum Test) erhalten kann?

Danke für deine Antworten.

BEARBEITET:

Ich habe meine Testmethode geändert:

@Test
public void testGetAll() {
    RestTemplate template = new RestTemplate();

    List<HttpMessageConverter<?>> messageConverters = new    ArrayList<HttpMessageConverter<?>>();
    Jaxb2RootElementHttpMessageConverter jaxbMessageConverter = new Jaxb2RootElementHttpMessageConverter();
    List<MediaType> mediaTypes = new ArrayList<MediaType>();
    mediaTypes.add(MediaType.APPLICATION_XML);
    jaxbMessageConverter.setSupportedMediaTypes(mediaTypes);
    messageConverters.add(jaxbMessageConverter);

    template.setMessageConverters(messageConverters);
    List list = template.getForObject(URL + "all",
            ArrayList.class);
    System.out.println(list);
}

Und ich bekam Ausnahme:

org.springframework.web.client.RestClientException: Could not extract response: no suitable HttpMessageConverter found for response type [class Java.util.ArrayList] and content type [application/xml]
at org.springframework.web.client.HttpMessageConverterExtractor.extractData(HttpMessageConverterExtractor.Java:107)
at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.Java:496)
at org.springframework.web.client.RestTemplate.execute(RestTemplate.Java:452)
at org.springframework.web.client.RestTemplate.getForObject(RestTemplate.Java:222)
at com.nixsolutions.web.service.rest.UserRESTServiceTest.testGetAll(UserRESTServiceTest.Java:61)
at Sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at Sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at Sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at Java.lang.reflect.Method.invoke(Unknown Source)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.Java:47)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.Java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.Java:44)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.Java:17)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.Java:271)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.Java:70)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.Java:50)
at org.junit.runners.ParentRunner$3.run(ParentRunner.Java:238)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.Java:63)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.Java:236)
at org.junit.runners.ParentRunner.access$000(ParentRunner.Java:53)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.Java:229)
at org.junit.runners.ParentRunner.run(ParentRunner.Java:309)
at org.Eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.Java:50)
at org.Eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.Java:38)
at org.Eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.Java:467)
at org.Eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.Java:683)
at org.Eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.Java:390)
at org.Eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.Java:197)
30
Cat H

vielleicht so ....

RestTemplate template = new RestTemplate(true);


ResponseEntity<TblGps[]> responseEntity = restTemplate.getForEntity(urlGETList, TblGps[].class);

TblGps[]=responseEntity.getBody();
42
kamokaze

Sie müssen eine konkrete Implementierung von List verwenden. Sie können beispielsweise ArrayList verwenden.

ResponseEntity<? extends ArrayList<User>> responseEntity = restTemplate.getForEntity(restEndPointUrl, (Class<? extends ArrayList<User>>)ArrayList.class, userId);

es funktioniert sogar für ein völlig generisches Setup:

ResponseEntity<? extends ArrayList<HashMap<String,Object>>> responseEntity = restTemplate.getForEntity(restEndPointUrl, (Class<? extends ArrayList<HashMap<String,Object>>>)ArrayList.class, parameterId);
7
chrismarx

Wenn Sie den Jaxb2RootElementHttpMessageConverter einstellen, überschreiben Sie die Standardkonverter, die mit RestTemplate geliefert werden. Einer der Standardkonverter (ich denke, das ist der String-Konverter) kann text/xml-Typ verarbeiten. Entfernen Sie den gesamten Jaxb2RootElementHttpMessageConverter, aber lassen Sie diesen Teil, wenn Sie ArrayList.class und nicht List.class erwartet haben. Dies wird funktionieren:

@Test
public void testGetAll() {
    RestTemplate template = new RestTemplate();
    List list = template.getForObject(URL + "all",
        ArrayList.class);
    System.out.println(list);
}

Möglicherweise müssen Sie auch einen accept-Header hinzufügen, um die Verwendung von text/xml und nicht einen der anderen produzierten Typen zu wählen:

HttpHeaders requestHeaders = new HttpHeaders();
requestHeaders.setAccept(Arrays.asList(new MediaType[] {MediaType.TEXT_XML}));

Und verwenden Sie exchange mit RestTemplate (anstelle von getForObject):

List list = template.exchange(URL + "all", new HttpEntity<String>(requestHeaders()), ArrayList.class);
5
Avi

Sie könnten restTemplate.getForEntity() verwenden. Sie erhalten ResponseEntity mit allen Antwortinformationen (einschließlich Status).

0
Admit