org.springframework.web.client.RestTemplate世上最全说明
下文笔者讲述RestTemplate世上最全讲解,如下所示
RestTemplate简介
RestTemplate是Spring框架中提供的用于发送HTTP请求的客户端工具 它遵循Restful原则 RestTemplate默认依赖JDK的Http连接工具HttpUrlConnection 也可替换不同的源 如: OkHttp、Apache HttpComponents等
RestTemplate数据转换
RestTemplate默认使用 转化HttpMessageConverter去将Http消息 转换成POJO或POJO转化成Http消息 在创建RestTemplate的时候会默认添加一组HttpMessageConveter的实现
HttpMessageConveter源码
public interface HttpMessageConverter<T> { //指示此转换器是否可以读取给定的类。 boolean canRead(Class<?> clazz, @Nullable MediaType mediaType); //指示此转换器是否可以写给定的类。 boolean canWrite(Class<?> clazz, @Nullable MediaType mediaType); //返回list<MediaType> List<MediaType> getSupportedMediaTypes(); //读取一个inputMessage T read(Class<? extends T> clazz, HttpInputMessage inputMessage) throws IOException, HttpMessageNotReadableException; //往output message写一个Object void write(T t, @Nullable MediaType contentType, HttpOutputMessage outputMessage) throws IOException, HttpMessageNotWritableException; }
RestTemplate中添加HttpMessageConverter的方法
static { ClassLoader classLoader = RestTemplate.class.getClassLoader(); romePresent = ClassUtils.isPresent("com.rometools.rome.feed.WireFeed", classLoader); jaxb2Present = ClassUtils.isPresent("javax.xml.bind.Binder", classLoader); jackson2Present = ClassUtils.isPresent("com.fasterxml.jackson.databind.ObjectMapper", classLoader) && ClassUtils.isPresent("com.fasterxml.jackson.core.JsonGenerator", classLoader); jackson2XmlPresent = ClassUtils.isPresent("com.fasterxml.jackson.dataformat.xml.XmlMapper", classLoader); jackson2SmilePresent = ClassUtils.isPresent("com.fasterxml.jackson.dataformat.smile.SmileFactory", classLoader); jackson2CborPresent = ClassUtils.isPresent("com.fasterxml.jackson.dataformat.cbor.CBORFactory", classLoader); gsonPresent = ClassUtils.isPresent("com.google.gson.Gson", classLoader); jsonbPresent = ClassUtils.isPresent("javax.json.bind.Jsonb", classLoader); } public RestTemplate() { this.messageConverters.add(new ByteArrayHttpMessageConverter()); this.messageConverters.add(new StringHttpMessageConverter()); this.messageConverters.add(new ResourceHttpMessageConverter(false)); try { this.messageConverters.add(new SourceHttpMessageConverter<>()); } catch (Error err) { // Ignore when no TransformerFactory implementation is available } this.messageConverters.add(new AllEncompassingFormHttpMessageConverter()); if (romePresent) { this.messageConverters.add(new AtomFeedHttpMessageConverter()); this.messageConverters.add(new RssChannelHttpMessageConverter()); } if (jackson2XmlPresent) { this.messageConverters.add(new MappingJackson2XmlHttpMessageConverter()); } else if (jaxb2Present) { this.messageConverters.add(new Jaxb2RootElementHttpMessageConverter()); } if (jackson2Present) { this.messageConverters.add(new MappingJackson2HttpMessageConverter()); } else if (gsonPresent) { this.messageConverters.add(new GsonHttpMessageConverter()); } else if (jsonbPresent) { this.messageConverters.add(new JsonbHttpMessageConverter()); } if (jackson2SmilePresent) { this.messageConverters.add(new MappingJackson2SmileHttpMessageConverter()); } if (jackson2CborPresent) { this.messageConverters.add(new MappingJackson2CborHttpMessageConverter()); } this.uriTemplateHandler = initUriTemplateHandler(); }
GET请求
getForEntity函数 返回对象是ResponseEntity ResponseEntity是对响应体的封装 包含响应状态码HttpStatus,响应头及相应体。 响应体可以是自定义对象 例 当User对象,则可以写成这样ResponseEntity getForEntity重载的函数有3个,使用及说明分别如下: getForEntity(URI url, Class responseType) 第一个参数是请求的URI 第二个参数是响应体的类型 UriComponents uriComponents = UriComponentsBuilder .fromUriString("http://localhost:8080/user/getByName?name={name}") .build() .expand("java265") // 设置参数值 .encode(); URI uri = uriComponents.toUri(); RestTemplate restTemplate = new RestTemplate(); ResponseEntity<User> responseEntity = restTemplate.getForEntity(uri, User.class); User user = responseEntity.getBody(); // 获取body体 getForEntity(String url, Class responseType, Map<String, ?> uriVariables), 第一个参数是请求的地址 第二个参数是响应体的返回类型 第三个参数提供url中的参数绑定,进行参数绑定时需要在占位符中指定Map中的key 例 url为htttp://localhost:8080/user/getByName?name={name},则需要在Map中put一个key为name的值 String url = "http://localhost:8080/user/getByName?name={name}"; Map<String, String> params = new HashMap(); params.put("name", "java265"); RestTemplate restTemplate = new RestTemplate(); ResponseEntity<User> responseEntity = restTemplate.getForEntity(url, User.class, params); User user = responseEntity.getBody(); getForEntity(String url, Class responseType, Object… uriVariables) 第一个参数是请求的url,第二个参数是响应体的返回类型,第三个参数提供url中的参数绑定, 绑定根据占位符的数字获取uriVariables数组中相应位置的值 例 url为htttp://localhost:8080/user/getByCond?name={1}&age={2}, 则name的值为uriVariables数组中第一个值,age为uriVariables数组中第二个值。 String url = "http://localhost:8080/user/getByCond?name={1}&age={2}"; RestTemplate restTemplate = new RestTemplate(); ResponseEntity<User> responseEntity = restTemplate.getForEntity(url, User.class, "java265", 88); User user = responseEntity.getBody();
getForObject
getForObject: 返回对象是响应体的内容 当不关心响应码、响应头信息可以使用此方法 同样提供了3个重载的方法。 getForObject(URI url, Class responseType) 参数同getForEntity(URI url, Class responseType) getForObject(String url, Class responseType, Map<String, ?> uriVariables) 参数同getForEntity(String url, Class responseType, Map<String, ?> uriVariables) getForObject(String url, Class responseType, Object… uriVariables) 参数同getForEntity(String url, Class responseType, Object… uriVariables)
POST请求
第一种方式 postForEntity返回对象是ResponseEntity是对请求响应的封装 包含响应码HttpStatus、响应头及响应体信息,提供了3个重载的方法 与get请求对应的方法不同的地方是多了一个入参,用来传递请求头、请求体参数 postForEntity(URI url, @Nullable Object request, Class responseType) 第一个参数是请求的URI资源,URI的构造具体可参考jdk的API, 第二个参数可以是一个普通对象,也可以是一个HttpEntity对象 当是一个普通对象RestTemplate会将请求对象装换为一个HttpEntity对象来处理 其中Object是request的类型,request内容会被视作完整的body来处理 而如果request是一个HttpEntity对象,则会被当作一个完整的HTTP请求对象来处理 这个request中不仅包含了body的内容还包含了header中的内容 第三个参数是响应体的返回类型 postForEntity(String url, @Nullable Object request, Class responseType, Map<String, ?> uriVariables) 第一个参数是请求的url 第二个参数封装请求体请求头信息 第三个参数是响应体的返回类型 第四个参数提供url中的参数绑定 url中的占位符即为Map中的key。 postForEntity(String url, @Nullable Object request, Class responseType, Object… uriVariables) 第一个参数为请求的url 第二个参数封装请求体请求头信息 第三个参数为响应体的类型 第四个参数是一个不定参数,用于url中参数绑定 占位符的值即为数组的顺序位置的值。 第二种方式 postForObject返回值为响应体的类型 提供了3个重载的方法 参数的作用同postForEntity。 postForObject(URI url, @Nullable Object request, Class responseType) postForObject(String url, @Nullable Object request, Class respon seType,Map<String, ?> uriVariables) postForObject(String url, @Nullable Object request, Class responseType, Object… uriVariables) 第三种方式:postForLocation此种方式较少使用 该方式实现了以post请求提交资源,并返回新资源的URI 由于确定了方法的返回类型,此次较postForEntity和postForObject少一个参数 同样提供了3个重载的方法,参数作用同postForEntity postForLocation(URI url, @Nullable Object request) postForLocation(String url, @Nullable Object request, Map<String, ?> uriVariables) postForLocation(String url, @Nullable Object request, Object… uriVariables)
PUT请求
put请求无返回值,提供了3个重载的方法。 put(URI url, @Nullable Object request) 第一个参数是请求的URI资源 第二个参数同样是请求体请求头的封装,可以是一般对象,也可以是HttpEntity对象 put(String url, @Nullable Object request, Map<String, ?> uriVariables) 第一个参数是请求的url 第二个参数是请求体请求头的封装 第三个参数提供url参数的绑定,url中占位符即为Map中的key put(String url, @Nullable Object request, Object… uriVariables) 第一个参数请求的url 第二个参数封装请求体请求头信息 第三个不定参数用于url参数绑定
DELETE请求
delete请求无返回值,提供了3个重载的方法。 delete(URI url)参数URI为请求的URI资源 delete(String url, Map<String, ?> uriVariables) 第一个参数是请求的url 第二个参数用于url参数的绑定 delete(String url, Object… uriVariables) 第一个参数是请求的url 第二个参数用于url参数的绑定
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。