public interface RestOperations
Implemented by RestTemplate. Not often used directly, but a useful
 option to enhance testability, as it can easily be mocked or stubbed.
RestTemplate| Modifier and Type | Method and Description | 
|---|---|
| void | delete(String url,
      Map<String,?> uriVariables)Delete the resources at the specified URI. | 
| void | delete(String url,
      Object... uriVariables)Delete the resources at the specified URI. | 
| void | delete(URI url)Delete the resources at the specified URL. | 
| <T> ResponseEntity<T> | exchange(RequestEntity<?> requestEntity,
        Class<T> responseType)Execute the request specified in the given  RequestEntityand return
 the response asResponseEntity. | 
| <T> ResponseEntity<T> | exchange(RequestEntity<?> requestEntity,
        ParameterizedTypeReference<T> responseType)Execute the request specified in the given  RequestEntityand return
 the response asResponseEntity. | 
| <T> ResponseEntity<T> | exchange(String url,
        HttpMethod method,
        HttpEntity<?> requestEntity,
        Class<T> responseType,
        Map<String,?> uriVariables)Execute the HTTP method to the given URI template, writing the given request entity to the request,
 and return the response as  ResponseEntity. | 
| <T> ResponseEntity<T> | exchange(String url,
        HttpMethod method,
        HttpEntity<?> requestEntity,
        Class<T> responseType,
        Object... uriVariables)Execute the HTTP method to the given URI template, writing the given request entity to the request,
 and return the response as  ResponseEntity. | 
| <T> ResponseEntity<T> | exchange(String url,
        HttpMethod method,
        HttpEntity<?> requestEntity,
        ParameterizedTypeReference<T> responseType,
        Map<String,?> uriVariables)Execute the HTTP method to the given URI template, writing the given
 request entity to the request, and return the response as  ResponseEntity. | 
| <T> ResponseEntity<T> | exchange(String url,
        HttpMethod method,
        HttpEntity<?> requestEntity,
        ParameterizedTypeReference<T> responseType,
        Object... uriVariables)Execute the HTTP method to the given URI template, writing the given
 request entity to the request, and return the response as  ResponseEntity. | 
| <T> ResponseEntity<T> | exchange(URI url,
        HttpMethod method,
        HttpEntity<?> requestEntity,
        Class<T> responseType)Execute the HTTP method to the given URI template, writing the given request entity to the request,
 and return the response as  ResponseEntity. | 
| <T> ResponseEntity<T> | exchange(URI url,
        HttpMethod method,
        HttpEntity<?> requestEntity,
        ParameterizedTypeReference<T> responseType)Execute the HTTP method to the given URI template, writing the given
 request entity to the request, and return the response as  ResponseEntity. | 
| <T> T | execute(String url,
       HttpMethod method,
       RequestCallback requestCallback,
       ResponseExtractor<T> responseExtractor,
       Map<String,?> uriVariables)Execute the HTTP method to the given URI template, preparing the request with the
  RequestCallback, and reading the response with aResponseExtractor. | 
| <T> T | execute(String url,
       HttpMethod method,
       RequestCallback requestCallback,
       ResponseExtractor<T> responseExtractor,
       Object... uriVariables)Execute the HTTP method to the given URI template, preparing the request with the
  RequestCallback, and reading the response with aResponseExtractor. | 
| <T> T | execute(URI url,
       HttpMethod method,
       RequestCallback requestCallback,
       ResponseExtractor<T> responseExtractor)Execute the HTTP method to the given URL, preparing the request with the
  RequestCallback, and reading the response with aResponseExtractor. | 
| <T> ResponseEntity<T> | getForEntity(String url,
            Class<T> responseType,
            Map<String,?> uriVariables)Retrieve a representation by doing a GET on the URI template. | 
| <T> ResponseEntity<T> | getForEntity(String url,
            Class<T> responseType,
            Object... uriVariables)Retrieve an entity by doing a GET on the specified URL. | 
| <T> ResponseEntity<T> | getForEntity(URI url,
            Class<T> responseType)Retrieve a representation by doing a GET on the URL. | 
| <T> T | getForObject(String url,
            Class<T> responseType,
            Map<String,?> uriVariables)Retrieve a representation by doing a GET on the URI template. | 
| <T> T | getForObject(String url,
            Class<T> responseType,
            Object... uriVariables)Retrieve a representation by doing a GET on the specified URL. | 
| <T> T | getForObject(URI url,
            Class<T> responseType)Retrieve a representation by doing a GET on the URL. | 
| HttpHeaders | headForHeaders(String url,
              Map<String,?> uriVariables)Retrieve all headers of the resource specified by the URI template. | 
| HttpHeaders | headForHeaders(String url,
              Object... uriVariables)Retrieve all headers of the resource specified by the URI template. | 
| HttpHeaders | headForHeaders(URI url)Retrieve all headers of the resource specified by the URL. | 
| Set<HttpMethod> | optionsForAllow(String url,
               Map<String,?> uriVariables)Return the value of the  Allowheader for the given URI. | 
| Set<HttpMethod> | optionsForAllow(String url,
               Object... uriVariables)Return the value of the  Allowheader for the given URI. | 
| Set<HttpMethod> | optionsForAllow(URI url)Return the value of the  Allowheader for the given URL. | 
| <T> T | patchForObject(String url,
              Object request,
              Class<T> responseType,
              Map<String,?> uriVariables)Update a resource by PATCHing the given object to the URI template,
 and return the representation found in the response. | 
| <T> T | patchForObject(String url,
              Object request,
              Class<T> responseType,
              Object... uriVariables)Update a resource by PATCHing the given object to the URI template,
 and return the representation found in the response. | 
| <T> T | patchForObject(URI url,
              Object request,
              Class<T> responseType)Update a resource by PATCHing the given object to the URL,
 and return the representation found in the response. | 
| <T> ResponseEntity<T> | postForEntity(String url,
             Object request,
             Class<T> responseType,
             Map<String,?> uriVariables)Create a new resource by POSTing the given object to the URI template,
 and return the response as  HttpEntity. | 
| <T> ResponseEntity<T> | postForEntity(String url,
             Object request,
             Class<T> responseType,
             Object... uriVariables)Create a new resource by POSTing the given object to the URI template,
 and return the response as  ResponseEntity. | 
| <T> ResponseEntity<T> | postForEntity(URI url,
             Object request,
             Class<T> responseType)Create a new resource by POSTing the given object to the URL,
 and return the response as  ResponseEntity. | 
| URI | postForLocation(String url,
               Object request,
               Map<String,?> uriVariables)Create a new resource by POSTing the given object to the URI template, and return the value of
 the  Locationheader. | 
| URI | postForLocation(String url,
               Object request,
               Object... uriVariables)Create a new resource by POSTing the given object to the URI template, and return the value of
 the  Locationheader. | 
| URI | postForLocation(URI url,
               Object request)Create a new resource by POSTing the given object to the URL, and return the value of the
  Locationheader. | 
| <T> T | postForObject(String url,
             Object request,
             Class<T> responseType,
             Map<String,?> uriVariables)Create a new resource by POSTing the given object to the URI template,
 and return the representation found in the response. | 
| <T> T | postForObject(String url,
             Object request,
             Class<T> responseType,
             Object... uriVariables)Create a new resource by POSTing the given object to the URI template,
 and return the representation found in the response. | 
| <T> T | postForObject(URI url,
             Object request,
             Class<T> responseType)Create a new resource by POSTing the given object to the URL,
 and return the representation found in the response. | 
| void | put(String url,
   Object request,
   Map<String,?> uriVariables)Creates a new resource by PUTting the given object to URI template. | 
| void | put(String url,
   Object request,
   Object... uriVariables)Create or update a resource by PUTting the given object to the URI. | 
| void | put(URI url,
   Object request)Creates a new resource by PUTting the given object to URL. | 
@Nullable <T> T getForObject(String url, Class<T> responseType, Object... uriVariables) throws RestClientException
URI Template variables are expanded using the given URI variables, if any.
url - the URLresponseType - the type of the return valueuriVariables - the variables to expand the templateRestClientException@Nullable <T> T getForObject(String url, Class<T> responseType, Map<String,?> uriVariables) throws RestClientException
URI Template variables are expanded using the given map.
url - the URLresponseType - the type of the return valueuriVariables - the map containing variables for the URI templateRestClientException@Nullable <T> T getForObject(URI url, Class<T> responseType) throws RestClientException
url - the URLresponseType - the type of the return valueRestClientException<T> ResponseEntity<T> getForEntity(String url, Class<T> responseType, Object... uriVariables) throws RestClientException
ResponseEntity.
 URI Template variables are expanded using the given URI variables, if any.
url - the URLresponseType - the type of the return valueuriVariables - the variables to expand the templateRestClientException<T> ResponseEntity<T> getForEntity(String url, Class<T> responseType, Map<String,?> uriVariables) throws RestClientException
ResponseEntity.
 URI Template variables are expanded using the given map.
url - the URLresponseType - the type of the return valueuriVariables - the map containing variables for the URI templateRestClientException<T> ResponseEntity<T> getForEntity(URI url, Class<T> responseType) throws RestClientException
ResponseEntity.url - the URLresponseType - the type of the return valueRestClientExceptionHttpHeaders headForHeaders(String url, Object... uriVariables) throws RestClientException
URI Template variables are expanded using the given URI variables, if any.
url - the URLuriVariables - the variables to expand the templateRestClientExceptionHttpHeaders headForHeaders(String url, Map<String,?> uriVariables) throws RestClientException
URI Template variables are expanded using the given map.
url - the URLuriVariables - the map containing variables for the URI templateRestClientExceptionHttpHeaders headForHeaders(URI url) throws RestClientException
url - the URLRestClientException@Nullable URI postForLocation(String url, @Nullable Object request, Object... uriVariables) throws RestClientException
Location header. This header typically indicates where the new resource is stored.
 URI Template variables are expanded using the given URI variables, if any.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
The body of the entity, or request itself, can be a
 MultiValueMap to create a multipart request.
 The values in the MultiValueMap can be any Object representing the body of the part,
 or an HttpEntity representing a part with body
 and headers.
url - the URLrequest - the Object to be POSTed (may be null)uriVariables - the variables to expand the templateLocation headerRestClientExceptionHttpEntity@Nullable URI postForLocation(String url, @Nullable Object request, Map<String,?> uriVariables) throws RestClientException
Location header. This header typically indicates where the new resource is stored.
 URI Template variables are expanded using the given map.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request
 
The body of the entity, or request itself, can be a
 MultiValueMap to create a multipart request.
 The values in the MultiValueMap can be any Object representing the body of the part,
 or an HttpEntity representing a part with body
 and headers.
url - the URLrequest - the Object to be POSTed (may be null)uriVariables - the variables to expand the templateLocation headerRestClientExceptionHttpEntity@Nullable URI postForLocation(URI url, @Nullable Object request) throws RestClientException
Location header. This header typically indicates where the new resource is stored.
 The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
The body of the entity, or request itself, can be a
 MultiValueMap to create a multipart request.
 The values in the MultiValueMap can be any Object representing the body of the part,
 or an HttpEntity representing a part with body
 and headers.
url - the URLrequest - the Object to be POSTed (may be null)Location headerRestClientExceptionHttpEntity@Nullable <T> T postForObject(String url, @Nullable Object request, Class<T> responseType, Object... uriVariables) throws RestClientException
URI Template variables are expanded using the given URI variables, if any.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
The body of the entity, or request itself, can be a
 MultiValueMap to create a multipart request.
 The values in the MultiValueMap can be any Object representing the body of the part,
 or an HttpEntity representing a part with body
 and headers.
url - the URLrequest - the Object to be POSTed (may be null)responseType - the type of the return valueuriVariables - the variables to expand the templateRestClientExceptionHttpEntity@Nullable <T> T postForObject(String url, @Nullable Object request, Class<T> responseType, Map<String,?> uriVariables) throws RestClientException
URI Template variables are expanded using the given map.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
The body of the entity, or request itself, can be a
 MultiValueMap to create a multipart request.
 The values in the MultiValueMap can be any Object representing the body of the part,
 or an HttpEntity representing a part with body
 and headers.
url - the URLrequest - the Object to be POSTed (may be null)responseType - the type of the return valueuriVariables - the variables to expand the templateRestClientExceptionHttpEntity@Nullable <T> T postForObject(URI url, @Nullable Object request, Class<T> responseType) throws RestClientException
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
The body of the entity, or request itself, can be a
 MultiValueMap to create a multipart request.
 The values in the MultiValueMap can be any Object representing the body of the part,
 or an HttpEntity representing a part with body
 and headers.
url - the URLrequest - the Object to be POSTed (may be null)responseType - the type of the return valueRestClientExceptionHttpEntity<T> ResponseEntity<T> postForEntity(String url, @Nullable Object request, Class<T> responseType, Object... uriVariables) throws RestClientException
ResponseEntity.
 URI Template variables are expanded using the given URI variables, if any.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
The body of the entity, or request itself, can be a
 MultiValueMap to create a multipart request.
 The values in the MultiValueMap can be any Object representing the body of the part,
 or an HttpEntity representing a part with body
 and headers.
url - the URLrequest - the Object to be POSTed (may be null)uriVariables - the variables to expand the templateRestClientExceptionHttpEntity<T> ResponseEntity<T> postForEntity(String url, @Nullable Object request, Class<T> responseType, Map<String,?> uriVariables) throws RestClientException
HttpEntity.
 URI Template variables are expanded using the given map.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
The body of the entity, or request itself, can be a
 MultiValueMap to create a multipart request.
 The values in the MultiValueMap can be any Object representing the body of the part,
 or an HttpEntity representing a part with body
 and headers.
url - the URLrequest - the Object to be POSTed (may be null)uriVariables - the variables to expand the templateRestClientExceptionHttpEntity<T> ResponseEntity<T> postForEntity(URI url, @Nullable Object request, Class<T> responseType) throws RestClientException
ResponseEntity.
 The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
The body of the entity, or request itself, can be a
 MultiValueMap to create a multipart request.
 The values in the MultiValueMap can be any Object representing the body of the part,
 or an HttpEntity representing a part with body
 and headers.
url - the URLrequest - the Object to be POSTed (may be null)RestClientExceptionHttpEntityvoid put(String url, @Nullable Object request, Object... uriVariables) throws RestClientException
URI Template variables are expanded using the given URI variables, if any.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
url - the URLrequest - the Object to be PUT (may be null)uriVariables - the variables to expand the templateRestClientExceptionHttpEntityvoid put(String url, @Nullable Object request, Map<String,?> uriVariables) throws RestClientException
URI Template variables are expanded using the given map.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
url - the URLrequest - the Object to be PUT (may be null)uriVariables - the variables to expand the templateRestClientExceptionHttpEntityvoid put(URI url, @Nullable Object request) throws RestClientException
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
url - the URLrequest - the Object to be PUT (may be null)RestClientExceptionHttpEntity@Nullable <T> T patchForObject(String url, @Nullable Object request, Class<T> responseType, Object... uriVariables) throws RestClientException
URI Template variables are expanded using the given URI variables, if any.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
NOTE: The standard JDK HTTP library does not support HTTP PATCH. You need to use e.g. the Apache HttpComponents request factory.
url - the URLrequest - the object to be PATCHed (may be null)responseType - the type of the return valueuriVariables - the variables to expand the templateRestClientExceptionHttpEntity, 
InterceptingHttpAccessor.setRequestFactory(org.springframework.http.client.ClientHttpRequestFactory), 
HttpComponentsClientHttpRequestFactory@Nullable <T> T patchForObject(String url, @Nullable Object request, Class<T> responseType, Map<String,?> uriVariables) throws RestClientException
URI Template variables are expanded using the given map.
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
NOTE: The standard JDK HTTP library does not support HTTP PATCH. You need to use e.g. the Apache HttpComponents request factory.
url - the URLrequest - the object to be PATCHed (may be null)responseType - the type of the return valueuriVariables - the variables to expand the templateRestClientExceptionHttpEntity, 
InterceptingHttpAccessor.setRequestFactory(org.springframework.http.client.ClientHttpRequestFactory), 
HttpComponentsClientHttpRequestFactory@Nullable <T> T patchForObject(URI url, @Nullable Object request, Class<T> responseType) throws RestClientException
The request parameter can be a HttpEntity in order to
 add additional HTTP headers to the request.
 
NOTE: The standard JDK HTTP library does not support HTTP PATCH. You need to use e.g. the Apache HttpComponents request factory.
url - the URLrequest - the object to be PATCHed (may be null)responseType - the type of the return valueRestClientExceptionHttpEntity, 
InterceptingHttpAccessor.setRequestFactory(org.springframework.http.client.ClientHttpRequestFactory), 
HttpComponentsClientHttpRequestFactoryvoid delete(String url, Object... uriVariables) throws RestClientException
URI Template variables are expanded using the given URI variables, if any.
url - the URLuriVariables - the variables to expand in the templateRestClientExceptionvoid delete(String url, Map<String,?> uriVariables) throws RestClientException
URI Template variables are expanded using the given map.
url - the URLuriVariables - the variables to expand the templateRestClientExceptionvoid delete(URI url) throws RestClientException
url - the URLRestClientExceptionSet<HttpMethod> optionsForAllow(String url, Object... uriVariables) throws RestClientException
Allow header for the given URI.
 URI Template variables are expanded using the given URI variables, if any.
url - the URLuriVariables - the variables to expand in the templateAllow headerRestClientExceptionSet<HttpMethod> optionsForAllow(String url, Map<String,?> uriVariables) throws RestClientException
Allow header for the given URI.
 URI Template variables are expanded using the given map.
url - the URLuriVariables - the variables to expand in the templateAllow headerRestClientExceptionSet<HttpMethod> optionsForAllow(URI url) throws RestClientException
Allow header for the given URL.url - the URLAllow headerRestClientException<T> ResponseEntity<T> exchange(String url, HttpMethod method, @Nullable HttpEntity<?> requestEntity, Class<T> responseType, Object... uriVariables) throws RestClientException
ResponseEntity.
 URI Template variables are expanded using the given URI variables, if any.
url - the URLmethod - the HTTP method (GET, POST, etc)requestEntity - the entity (headers and/or body) to write to the request
 may be null)responseType - the type to convert the response to, or Void.class for no bodyuriVariables - the variables to expand in the templateRestClientException<T> ResponseEntity<T> exchange(String url, HttpMethod method, @Nullable HttpEntity<?> requestEntity, Class<T> responseType, Map<String,?> uriVariables) throws RestClientException
ResponseEntity.
 URI Template variables are expanded using the given URI variables, if any.
url - the URLmethod - the HTTP method (GET, POST, etc)requestEntity - the entity (headers and/or body) to write to the request
 (may be null)responseType - the type to convert the response to, or Void.class for no bodyuriVariables - the variables to expand in the templateRestClientException<T> ResponseEntity<T> exchange(URI url, HttpMethod method, @Nullable HttpEntity<?> requestEntity, Class<T> responseType) throws RestClientException
ResponseEntity.url - the URLmethod - the HTTP method (GET, POST, etc)requestEntity - the entity (headers and/or body) to write to the request
 (may be null)responseType - the type to convert the response to, or Void.class for no bodyRestClientException<T> ResponseEntity<T> exchange(String url, HttpMethod method, @Nullable HttpEntity<?> requestEntity, ParameterizedTypeReference<T> responseType, Object... uriVariables) throws RestClientException
ResponseEntity.
 The given ParameterizedTypeReference is used to pass generic type information:
 
 ParameterizedTypeReference<List<MyBean>> myBean =
     new ParameterizedTypeReference<List<MyBean>>() {};
 ResponseEntity<List<MyBean>> response =
     template.exchange("https://example.com",HttpMethod.GET, null, myBean);
 url - the URLmethod - the HTTP method (GET, POST, etc)requestEntity - the entity (headers and/or body) to write to the
 request (may be null)responseType - the type to convert the response to, or Void.class for no bodyuriVariables - the variables to expand in the templateRestClientException<T> ResponseEntity<T> exchange(String url, HttpMethod method, @Nullable HttpEntity<?> requestEntity, ParameterizedTypeReference<T> responseType, Map<String,?> uriVariables) throws RestClientException
ResponseEntity.
 The given ParameterizedTypeReference is used to pass generic type information:
 
 ParameterizedTypeReference<List<MyBean>> myBean =
     new ParameterizedTypeReference<List<MyBean>>() {};
 ResponseEntity<List<MyBean>> response =
     template.exchange("https://example.com",HttpMethod.GET, null, myBean);
 url - the URLmethod - the HTTP method (GET, POST, etc)requestEntity - the entity (headers and/or body) to write to the request
 (may be null)responseType - the type to convert the response to, or Void.class for no bodyuriVariables - the variables to expand in the templateRestClientException<T> ResponseEntity<T> exchange(URI url, HttpMethod method, @Nullable HttpEntity<?> requestEntity, ParameterizedTypeReference<T> responseType) throws RestClientException
ResponseEntity.
 The given ParameterizedTypeReference is used to pass generic type information:
 
 ParameterizedTypeReference<List<MyBean>> myBean =
     new ParameterizedTypeReference<List<MyBean>>() {};
 ResponseEntity<List<MyBean>> response =
     template.exchange("https://example.com",HttpMethod.GET, null, myBean);
 url - the URLmethod - the HTTP method (GET, POST, etc)requestEntity - the entity (headers and/or body) to write to the request
 (may be null)responseType - the type to convert the response to, or Void.class for no bodyRestClientException<T> ResponseEntity<T> exchange(RequestEntity<?> requestEntity, Class<T> responseType) throws RestClientException
RequestEntity and return
 the response as ResponseEntity. Typically used in combination
 with the static builder methods on RequestEntity, for instance:
 
 MyRequest body = ...
 RequestEntity request = RequestEntity
     .post(new URI("https://example.com/foo"))
     .accept(MediaType.APPLICATION_JSON)
     .body(body);
 ResponseEntity<MyResponse> response = template.exchange(request, MyResponse.class);
 requestEntity - the entity to write to the requestresponseType - the type to convert the response to, or Void.class for no bodyRestClientException<T> ResponseEntity<T> exchange(RequestEntity<?> requestEntity, ParameterizedTypeReference<T> responseType) throws RestClientException
RequestEntity and return
 the response as ResponseEntity. The given
 ParameterizedTypeReference is used to pass generic type information:
 
 MyRequest body = ...
 RequestEntity request = RequestEntity
     .post(new URI("https://example.com/foo"))
     .accept(MediaType.APPLICATION_JSON)
     .body(body);
 ParameterizedTypeReference<List<MyResponse>> myBean =
     new ParameterizedTypeReference<List<MyResponse>>() {};
 ResponseEntity<List<MyResponse>> response = template.exchange(request, myBean);
 requestEntity - the entity to write to the requestresponseType - the type to convert the response to, or Void.class for no bodyRestClientException@Nullable <T> T execute(String url, HttpMethod method, @Nullable RequestCallback requestCallback, @Nullable ResponseExtractor<T> responseExtractor, Object... uriVariables) throws RestClientException
RequestCallback, and reading the response with a ResponseExtractor.
 URI Template variables are expanded using the given URI variables, if any.
url - the URLmethod - the HTTP method (GET, POST, etc)requestCallback - object that prepares the requestresponseExtractor - object that extracts the return value from the responseuriVariables - the variables to expand in the templateResponseExtractorRestClientException@Nullable <T> T execute(String url, HttpMethod method, @Nullable RequestCallback requestCallback, @Nullable ResponseExtractor<T> responseExtractor, Map<String,?> uriVariables) throws RestClientException
RequestCallback, and reading the response with a ResponseExtractor.
 URI Template variables are expanded using the given URI variables map.
url - the URLmethod - the HTTP method (GET, POST, etc)requestCallback - object that prepares the requestresponseExtractor - object that extracts the return value from the responseuriVariables - the variables to expand in the templateResponseExtractorRestClientException@Nullable <T> T execute(URI url, HttpMethod method, @Nullable RequestCallback requestCallback, @Nullable ResponseExtractor<T> responseExtractor) throws RestClientException
RequestCallback, and reading the response with a ResponseExtractor.url - the URLmethod - the HTTP method (GET, POST, etc)requestCallback - object that prepares the requestresponseExtractor - object that extracts the return value from the responseResponseExtractorRestClientException