java使用RestTemplate封裝post請求方式
使用RestTemplate封裝post請求
之前筆者寫過一篇比較實(shí)用的文章 java使用httpclient封裝post請求和get的請求,其實(shí)java中實(shí)現(xiàn)http請求還可以用 RestTemplate 完成,下面給出示例代碼:
import com.alibaba.fastjson.JSONObject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.http.*;
import org.springframework.http.converter.StringHttpMessageConverter;
import org.springframework.web.client.RestTemplate;
import javax.annotation.PostConstruct;
import java.nio.charset.Charset;
public class HttpHelper {
private static Logger logger = LoggerFactory.getLogger(HttpHelper.class);
private RestTemplate restTemplate;
private HttpHeaders httpHeaders;
@PostConstruct
public void init() {
restTemplate = new RestTemplate();
restTemplate.getMessageConverters().add(0, new StringHttpMessageConverter(Charset.forName("UTF-8")));
httpHeaders = new HttpHeaders();
httpHeaders.setContentType(org.springframework.http.MediaType.APPLICATION_JSON);
}
/**
* post - json
* @param params
* @return
*/
public String post(JSONObject params, String url) {
logger.info("請求參數(shù):{}", params.toJSONString());
ResponseEntity<String> response;
try {
response = restTemplate.exchange(
url,
HttpMethod.POST,
new HttpEntity<>(params, httpHeaders),
String.class);
} catch (Exception e) {
logger.error("請求異常", e);
return "請求異常";
}
logger.info("響應(yīng)結(jié)果:{}", JSONObject.toJSONString(response));
if (response.getStatusCode().equals(HttpStatus.OK)) {
logger.info("請求成功,返回結(jié)果:{}", response.getBody());
return response.getBody();
}
logger.error("請求失敗,Http狀態(tài)碼:{},返回結(jié)果:{}", response.getStatusCode(), response.getBody());
return response.getBody();
}
}
RestTemplate 是 Spring 提供的用于訪問Rest服務(wù)的客戶端,RestTemplate 提供了多種便捷訪問遠(yuǎn)程Http 服務(wù)的方法,能夠大大提高客戶端的編寫效率。
RestTemplate使用封裝
之前接口調(diào)用習(xí)慣性使用HttpClient,代碼復(fù)雜,冗余代碼多,關(guān)心資源回收用起來不是很爽。
RestTemplate默認(rèn)依賴jdk的HTTP連接工具。也可以 通過setRequestFactory屬性切換到不同的HTTP源,比如Apache HttpComponents、Netty、OkHttp。
1、SpringBoot使用RestTemplate(使用apache的httpclient)
import org.springframework.boot.web.client.RestTemplateBuilder;
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.http.converter.ByteArrayHttpMessageConverter;
import org.springframework.http.converter.FormHttpMessageConverter;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.http.converter.ResourceHttpMessageConverter;
import org.springframework.http.converter.StringHttpMessageConverter;
import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;
import org.springframework.http.converter.support.AllEncompassingFormHttpMessageConverter;
import org.springframework.web.client.RestTemplate;
import java.nio.charset.Charset;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.TimeUnit;
@Configuration
public class RestTemplateConfig {
@Bean
public RestTemplate getRestTemplate() {
//手動(dòng)指定轉(zhuǎn)換器(HttpMessageConverter)
List<HttpMessageConverter<?>> messageConverters = new ArrayList<HttpMessageConverter<?>>();
messageConverters.add(new ByteArrayHttpMessageConverter());
messageConverters.add(new StringHttpMessageConverter(Charset.forName("UTF-8")));//string強(qiáng)制使用UTF-8
messageConverters.add(new ResourceHttpMessageConverter());
messageConverters.add(new AllEncompassingFormHttpMessageConverter());
messageConverters.add(new FormHttpMessageConverter());
MappingJackson2HttpMessageConverter jacksonConverter = new MappingJackson2HttpMessageConverter();
jacksonConverter.getObjectMapper().setDateFormat(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"));
messageConverters.add(jacksonConverter);
RestTemplate restTemplate = new RestTemplateBuilder().additionalMessageConverters(messageConverters).build();
restTemplate.setRequestFactory(getClientHttpRequestFactory());
return restTemplate;
}
@Bean
public ClientHttpRequestFactory getClientHttpRequestFactory() {
// 保持長連接配置,需要在頭添加Keep-Alive
final ConnectionKeepAliveStrategy myStrategy = new ConnectionKeepAliveStrategy() {
@Override
public long getKeepAliveDuration(org.apache.http.HttpResponse response, HttpContext context) {
// 設(shè)置一個(gè)鏈接的最大存活時(shí)間
return 5 * 1000L;
}
};
PoolingHttpClientConnectionManager pollingConnectionManager = new PoolingHttpClientConnectionManager(30, TimeUnit.SECONDS);
pollingConnectionManager.setMaxTotal(2000);//最大連接數(shù)
pollingConnectionManager.setDefaultMaxPerRoute(200);//同路由的最大連接數(shù)
CloseableHttpClient closeableHttpClient = HttpClientBuilder.create().setConnectionManager(pollingConnectionManager).setKeepAliveStrategy(myStrategy).build();
HttpComponentsClientHttpRequestFactory factory = new HttpComponentsClientHttpRequestFactory(closeableHttpClient);
factory.setConnectTimeout(3000);
factory.setReadTimeout(5000);
return factory;
}
}
2、使用jdk原生的
// 添加消息轉(zhuǎn)換器 List messageConverters = new ArrayList(); messageConverters.add(new StringHttpMessageConverter()); messageConverters.add(new MappingJackson2HttpMessageConverter()); //如果useJ2SEHttp申明為true,則使用JDK自帶的HttpURLConnection SimpleClientHttpRequestFactory requestFactory = new SimpleClientHttpRequestFactory(); requestFactory.setReadTimeout(3000); requestFactory.setConnectTimeout(3000); restTemplate = new RestTemplate(requestFactory); restTemplate.setMessageConverters(messageConverters); //這里是添加了攔截器 List<ClientHttpRequestInterceptor> interceptorList = new ArrayList<ClientHttpRequestInterceptor>(); interceptorList.add(new RequestInteceptor()); restTemplate.setInterceptors(interceptorList);
2、攔截器實(shí)現(xiàn)ClientHttpRequestInterceptor
(設(shè)置頭信息的時(shí)候回使用到)
public class RequestInteceptor implements ClientHttpRequestInterceptor {
@Override
public ClientHttpResponse intercept(HttpRequest request, byte[] body, ClientHttpRequestExecution execution) throws IOException {
request.getHeaders().setAll(AppMetadataUtil.getAPP_METADATA());
String traceId = UUID.randomUUID().toString().replaceAll("-", "");
request.getHeaders().set("TraceId", traceId.toString());
return execution.execute(request, body);
}
}
4、常用的方法
String url = queryInfo?userId={userId}&pageIndex={pageIndex}&pageSize={pageSize}";
HashMap<String,Object> parameterMap = new HashMap<String,Object>();
parameterMap.put("userId", userId);
parameterMap.put("pageIndex", pageIndex);
parameterMap.put("pageSize", pageSize);
String str = restTemplate.getForObject(url, String.class, parameterMap);
String result = restTemp.getForObject(requestUrl.toString(), String.class);
//post
String url = "http://www.xxx.com/queryInfo"
String str = restTemplate.postForObject(url, parameterMap, String.class);
//exchange 設(shè)置請求頭
HttpHeaders headers = new HttpHeaders();
headers.setContentType(MediaType.parseMediaType("application/json;charset=UTF-8"));
headers.add("Accept", "application/json;charset=UTF-8");
HttpEntity<String> httpEntity = new HttpEntity<String>("", headers);
RestTemplate restTemplate = RestTemplateUtils.getInstance().getRestTemplate();
ResponseEntity<String> exchange = restTemplate.exchange(retailOrderUrl, HttpMethod.GET, httpEntity, String.class);
String forObject = exchange.getBody();
MultiValueMap<String, Object> requestEntity = new LinkedMultiValueMap<>();
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
用Java連接sqlserver數(shù)據(jù)庫時(shí)候幾個(gè)jar包的區(qū)別分析
這篇文章主要介紹了用Java連接sqlserver數(shù)據(jù)庫時(shí)候幾個(gè)jar包的區(qū)別分析,需要的朋友可以參考下2014-10-10
Java實(shí)現(xiàn)多路復(fù)用select模型實(shí)例詳解
在計(jì)算機(jī)網(wǎng)絡(luò)中,多路復(fù)用(Multiplexing)指的是通過一種機(jī)制將多個(gè) I/O 操作合并到同一個(gè)線程或進(jìn)程中,從而提高系統(tǒng)的效率,在 Java 中,可以使用 Selector 類來實(shí)現(xiàn)基于 I/O 多路復(fù)用的模式,故本文給大家介紹了Java實(shí)現(xiàn)多路復(fù)用select模型實(shí)例,需要的朋友可以參考下2025-03-03
java依賴jave-all-deps實(shí)現(xiàn)視頻格式轉(zhuǎn)換
jave-all-deps是一款基于FFmpeg庫的Java音視頻編解碼庫,本文主要介紹了java依賴jave-all-deps實(shí)現(xiàn)視頻格式轉(zhuǎn)換,具有一定的參考價(jià)值,感興趣的可以了解一下2024-07-07
解決SpringMVC @RequestMapping不設(shè)置value出現(xiàn)的問題
這篇文章主要介紹了解決SpringMVC @RequestMapping不設(shè)置value出現(xiàn)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
SpringBoot中的響應(yīng)式web應(yīng)用詳解
這篇文章主要介紹了SpringBoot中的響應(yīng)式web應(yīng)用詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
Sping?Security前后端分離兩種實(shí)戰(zhàn)方案
這篇文章主要介紹了Sping?Security前后端分離兩種方案,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03
Java 數(shù)據(jù)結(jié)構(gòu)進(jìn)階二叉樹題集上
二叉樹可以簡單理解為對于一個(gè)節(jié)點(diǎn)來說,最多擁有一個(gè)上級節(jié)點(diǎn),同時(shí)最多具備左右兩個(gè)下級節(jié)點(diǎn)的數(shù)據(jù)結(jié)構(gòu)。本文將帶你通過實(shí)際題目來熟練掌握2022-04-04
Java實(shí)現(xiàn)經(jīng)典游戲黃金礦工的示例代碼
《黃金礦工》游戲是一個(gè)經(jīng)典的抓金子小游戲,它可以鍛煉人的反應(yīng)能力。本文將用Java實(shí)現(xiàn)這一經(jīng)典的游戲,感興趣的小伙伴可以了解一下2022-02-02

