restTemplate的exchange请求如何实现

为什么要用RestTemplate??
  • 相信大家之前都用过apache的HTTPClient类,逻辑繁琐,代码复杂,还要自己编写使用类HttpClientUtil,封装对应的post,get,delete等方法。
  • RestTemplate的行为可以通过callback回调方法和配置HttpMessageConverter 来定制,用来把对象封装到HTTP请求体,将响应信息放到一个对象中。RestTemplate提供更高等级的符合HTTP的六种主要方法,可以很简单的调用RESTful服务。
使用方式
一、restTemplate注入到bean里面。
@Configuration
public class RestTempleConfig {
    
    @Bean
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }
}

也可以自己设置restTemplate的超时时间的一些设置

    /**
     * 替代默认的SimpleClientHttpRequestFactory
     * 设置超时时间重试次数
     * 同时设置一些拦截器以便监控
     * @return
     */
    @Bean
    public RestTemplate restTemplate() {
        //生成一个设置了连接超时时间、请求超时时间、异常重试次数3次
        RequestConfig config = RequestConfig.custom().setConnectionRequestTimeout(10000).setConnectTimeout(10000).setSocketTimeout(30000).build();
        HttpClientBuilder builder = HttpClientBuilder.create().setDefaultRequestConfig(config).setRetryHandler(new DefaultHttpRequestRetryHandler(3, false));
        HttpClient httpClient = builder.build();
        ClientHttpRequestFactory requestFactory = new HttpComponentsClientHttpRequestFactory(httpClient);
        RestTemplate restTemplate = new RestTemplate(requestFactory);
        //做个日志拦截器;从性能上考虑,当前屏蔽该功能
        //restTemplate.setInterceptors(Collections.singletonList(new RestTemplateConsumerLogger()));
        return restTemplate;
    }

若是要进行刚详细的操作可以查看官方文档

二、restTemplate的使用。
post方法
String reqJsonStr = "{\"code\":\"testCode\",\"order\":1}"; //拼装的条件
HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON);
HttpEntity<String> entity = new HttpEntity<String>(reqJsonStr,headers);
ResponseEntity<Map> resp = restTemplate.exchange(DIC_DATA_URL, HttpMethod.POST, entity, Map.class);
get方法
ResponseEntity<String> results = restTemplate.exchange(url,HttpMethod.GET, null, String.class, params);
put方法
String reqJsonStr = "{\"id\":227, \"order\":9}";
HttpHeaders headers = new HttpHeaders();
headers.setContentType(MediaType.APPLICATION_JSON);
HttpEntity<String> entity = new HttpEntity<String>(reqJsonStr,headers);
ResponseEntity<Map> resp = restTemplate.exchange(DIC_DATA_URL, HttpMethod.PUT, entity, Map.class);
delete方法
ResponseEntity<Map> resp = restTemplate.exchange(DIC_DATA_URL + "?id={id}", HttpMethod.DELETE, null, Map.class, 227);
说明
get和delete方法如果需要传token的话可以像post和put方法一样new一个HttpHeaders,然后将token放进去。

参数的说明
 	 1)url: 请求地址;
     2)method: 请求类型(如:POST,PUT,DELETE,GET);
     3)requestEntity: 请求实体,封装请求头,请求内容
     4)responseType: 响应类型,根据服务接口的返回类型决定
     5)uriVariables: url中参数变量值
  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用 `RestTemplate.exchange` 方法发送 HTTPS 请求时,如果服务器的证书不是由受信任的 CA 签发,那么默认情况下会抛出 `SSLHandshakeException` 异常,说明 SSL 握手失败。为了信任自签名的证书,可以通过以下步骤实现: 1. 创建一个 `RestTemplate` 实例,并设置其 `HttpClient` 配置。 ```java RestTemplate restTemplate = new RestTemplate(); CloseableHttpClient httpClient = HttpClients.custom() .setSSLContext(createSSLContext()) .setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE) .build(); restTemplate.setRequestFactory(new HttpComponentsClientHttpRequestFactory(httpClient)); ``` 2. 创建一个 SSL 上下文对象,并初始化它。 ```java private SSLContext createSSLContext() throws Exception { SSLContext sslContext = SSLContext.getInstance("TLS"); sslContext.init(null, new TrustManager[]{new X509TrustManager() { public X509Certificate[] getAcceptedIssuers() { return null; } public void checkClientTrusted(X509Certificate[] certs, String authType) { } public void checkServerTrusted(X509Certificate[] certs, String authType) { } }}, new SecureRandom()); return sslContext; } ``` 这里创建了一个 `SSLContext` 实例,并初始化它,其中信任管理器(TrustManager)是一个匿名内部类,它会信任所有的证书。在实际情况中,可以根据需要实现自定义的信任管理器,来对证书进行合法性验证。 3. 设置 SSL 主机名验证程序。 ```java HostnameVerifier hostnameVerifier = new NoopHostnameVerifier(); SSLConnectionSocketFactory sslSocketFactory = new SSLConnectionSocketFactory(sslContext, hostnameVerifier); Registry<ConnectionSocketFactory> socketFactoryRegistry = RegistryBuilder.<ConnectionSocketFactory>create() .register("https", sslSocketFactory) .build(); PoolingHttpClientConnectionManager connectionManager = new PoolingHttpClientConnectionManager(socketFactoryRegistry); connectionManager.setMaxTotal(MAX_TOTAL_CONNECTIONS); connectionManager.setDefaultMaxPerRoute(MAX_CONNECTIONS_PER_ROUTE); httpClient = HttpClients.custom() .setConnectionManager(connectionManager) .disableCookieManagement() .build(); ``` 这里创建了一个 `HostnameVerifier` 实例,用于验证 SSL 握手过程中的主机名。为了信任所有主机名,使用了一个 `NoopHostnameVerifier` 实例。实际情况中,可以根据需要实现自定义的主机名验证程序。 4. 定义请求头和请求体。 ```java HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON); RequestBody requestBody = new RequestBody(); requestBody.setParam1("value1"); requestBody.setParam2("value2"); ``` 5. 构造一个 `HttpEntity` 实例,包含请求头和请求体。 ```java HttpEntity<RequestBody> requestEntity = new HttpEntity<>(requestBody, headers); ``` 6. 发送 HTTPS 请求,并获取响应结果。 ```java String url = "https://example.com/api"; ResponseEntity<String> responseEntity = restTemplate.exchange(url, HttpMethod.POST, requestEntity, String.class); String responseBody = responseEntity.getBody(); ``` 这里使用 `RestTemplate.exchange` 方法发送 HTTPS 请求,其内部会使用上述配置的 `HttpClient` 实例来发送请求。如果服务器证书不被信任,会抛出 `SSLHandshakeException` 异常,如果服务器证书被信任,则会返回响应结果。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值