SpringBoot之RestTemplate使用Apache的HttpClient连接池并解决中文乱码

SpringBoot自带的RestTemplate是没有使用连接池的,只是SimpleClientHttpRequestFactory实现了ClientHttpRequestFactory、AsyncClientHttpRequestFactory 2个工厂接口,因此每次调用接口都会创建连接和销毁连接,如果是高并发场景下会大大降低性能。因此,我们可以使用Apache的HttpClient连接池。

pom.xml

		<!-- RestTemplate使用Apache的HttpComponentsClientHttpRequestFactory替换掉Spring SimpleClientHttpRequestFactory 以使用Apache HttpClient的连接池。 -->
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient</artifactId>
        </dependency>

RestTemplate配置类

import org.apache.http.client.HttpClient;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.client.ClientHttpRequestFactory;
import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
import org.springframework.web.client.RestTemplate;

@Configuration
public class RestTemplateConfig {

    @Bean
    public RestTemplate restTemplate() {
        PoolingHttpClientConnectionManager connectionManager = new PoolingHttpClientConnectionManager();
        connectionManager.setMaxTotal(50);
        connectionManager.setDefaultMaxPerRoute(20);

        RequestConfig requestConfig = RequestConfig
                .custom()
                .setConnectionRequestTimeout(5000) // timeout to get connection from pool
                .setSocketTimeout(5000) // standard connection timeout
                .setConnectTimeout(5000) // standard connection timeout
                .build();

        HttpClient httpClient = HttpClientBuilder.create()
                .setConnectionManager(connectionManager)
                .setDefaultRequestConfig(requestConfig).build();

        ClientHttpRequestFactory requestFactory = new HttpComponentsClientHttpRequestFactory(httpClient);

        return new RestTemplate(requestFactory);
    }

}

调用

	@Autowired  
	private RestTemplate restTemplate;  
  
	public Res getData(Dto dto) {
		String url = "https://xxx.com/api/xxx";
		//封装请求头参数.
        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_JSON);
        headers.set("Content-Type", "application/json;charset=utf-8");
        headers.set("自定义请求头key","自定义请求头value");
        
        //防止中文乱码(不一定有用,如果还是乱码就改成byte[]接收,再new String(data, StandardCharsets.UTF_8);转为对应的编码)
        //restTemplate.getMessageConverters().set(1, new StringHttpMessageConverter(StandardCharsets.UTF_8));
		Res res = restTemplate.postForEntity(url, new HttpEntity<>(dto, headers), Res.class).getBody();
    	return res;
	}

用byte数组接收转码来解决中文乱码

String url = "https://xxx.com/api/xxx";
		//封装请求头参数.
        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_JSON);
        headers.set("Content-Type", "application/json;charset=utf-8");
        headers.set("自定义请求头key","自定义请求头value");
        
        //解决中文乱码
		byte[] data = restTemplate.postForEntity(url, new HttpEntity<>(dto, headers), byte[].class).getBody();
		String res = new String(data, StandardCharsets.UTF_8);
    	return res;
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot 默认使用 Apache HttpClient 作为 RestTemplate 的 HTTP 客户端。HttpClient 内部维护了一个连接池,可以提高连接的复用率和性能。 如果想要监听 RestTemplate连接池情况,可以通过 HttpClient连接池管理器进行实现。具体步骤如下: 1. 创建 HttpClient连接池管理器 ```java PoolingHttpClientConnectionManager connectionManager = new PoolingHttpClientConnectionManager(); ``` 2. 配置连接池参数 ```java connectionManager.setMaxTotal(200); // 最大连接数 connectionManager.setDefaultMaxPerRoute(20); // 每个路由的最大连接数 ``` 3. 创建 HttpClient 实例,并设置连接池管理器 ```java CloseableHttpClient httpClient = HttpClients.custom() .setConnectionManager(connectionManager) .build(); ``` 4. 将 HttpClient 实例设置到 RestTemplate 中 ```java RestTemplate restTemplate = new RestTemplate(new HttpComponentsClientHttpRequestFactory(httpClient)); ``` 5. 添加连接池监视器 ```java connectionManager.getTotalStats(); // 获取连接池统计信息 connectionManager.closeIdleConnections(30, TimeUnit.SECONDS); // 关闭空闲连接 ``` 可以在定时任务中调用 `connectionManager.getTotalStats()` 获取连接池的统计信息,例如当前连接数、空闲连接数、请求等待时间等。同时可以使用 `connectionManager.closeIdleConnections()` 方法关闭空闲连接,避免长时间占用连接资源。 注意:以上代码只是示例,具体实现需要根据自己的业务场景进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值