国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - RestTemplate實(shí)現(xiàn)發(fā)送帶headers的GET請求

RestTemplate實(shí)現(xiàn)發(fā)送帶headers的GET請求

2022-03-06 13:19肥魚先生 Java教程

這篇文章主要介紹了RestTemplate實(shí)現(xiàn)發(fā)送帶headers的GET請求,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

RestTemplate 發(fā)送帶headers的GET請求

需求:發(fā)送自定義header的GET請求,header中需要插入一個(gè)簽名。

發(fā)送自定義header的POST請求

之前寫過一個(gè)類似的請求,但是是POST的。這個(gè)也摸了一段時(shí)間,自己看參數(shù)整了出來。代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
// header填充
LinkedMultiValueMap<String, String> headers = new LinkedMultiValueMap<>();
headers.put("Content-Type", Collections.singletonList("application/json;charset=UTF-8"));
headers.put("signature", Collections.singletonList(makeSignature(form.getNewMobile())));
// body填充
JSONObject json = new JSONObject();
json.put("oldMobile", mobile);
json.put("newMobile", form.getNewMobile());
HttpEntity<String> request = new HttpEntity<String>(json.toString(), headers);
// 一個(gè)單例的restTemplate
RestTemplate restTemplate = HttpInvoker.getRestTemplate();
// 發(fā)送請求
ResponseEntity<String> response = restTemplate.postForEntity(whiteListURL, request, String.class);

很簡單的想著,只需要把上面的postForEntity()改成get的就行,但不是這樣的。

RestTemplate實(shí)現(xiàn)發(fā)送帶headers的GET請求

發(fā)送自定義header的GET請求

Update: 2019/12/11

從鏈接學(xué)到了一種比較友好的寫法:

?
1
2
3
4
5
6
7
8
9
private static void getEmployees(){
    final String uri = "http://localhost:8080/springrestexample/employees";
    RestTemplate restTemplate = new RestTemplate();
    HttpHeaders headers = new HttpHeaders();
    headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
    HttpEntity<String> entity = new HttpEntity<String>("parameters", headers);    
    ResponseEntity<String> result = restTemplate.exchange(uri, HttpMethod.GET, entity, String.class);    
    System.out.println(result);
}

粗略看了看postForEntity()和getForEntity()這兩個(gè)方法的實(shí)現(xiàn),都是準(zhǔn)備參數(shù),然后調(diào)用execute()方法,如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
// POST
@Override
public <T> ResponseEntity<T> postForEntity(String url, @Nullable Object request,
        Class<T> responseType, Object... uriVariables) throws RestClientException {
    RequestCallback requestCallback = httpEntityCallback(request, responseType);
    ResponseExtractor<ResponseEntity<T>> responseExtractor = responseEntityExtractor(responseType);
    return nonNull(execute(url, HttpMethod.POST, requestCallback, responseExtractor, uriVariables));
}
// GET
@Override
@Nullable
public <T> T getForObject(String url, Class<T> responseType, Map<String, ?> uriVariables) throws RestClientException {
    RequestCallback requestCallback = acceptHeaderRequestCallback(responseType);
    HttpMessageConverterExtractor<T> responseExtractor =
            new HttpMessageConverterExtractor<>(responseType, getMessageConverters(), logger);
    return execute(url, HttpMethod.GET, requestCallback, responseExtractor, uriVariables);
}

區(qū)別就在于RequestCallback實(shí)例化的時(shí)候,傳的參數(shù)不一樣。POST的時(shí)候,是將header做為參數(shù)傳給了RequestCallback。再然后就是execute()中的GET和POST參數(shù)不一樣。到這個(gè)時(shí)候,發(fā)送自定義header的GET請求,已經(jīng)很明顯了。

實(shí)例化的函數(shù),都是public的

如果不是public的,或者說我們不能直接訪問到,還可以考慮通過反射的方式去調(diào)用相關(guān)的方法,但這里不需要用反射了。

結(jié)果

?
1
2
3
4
5
6
7
8
9
10
11
12
// header填充
LinkedMultiValueMap<String, String> headers = new LinkedMultiValueMap<>();
headers.put("Content-Type", Collections.singletonList("application/json;charset=UTF-8"));
headers.put("signature", Collections.singletonList(makeSignature(mobile)));
// 獲取單例RestTemplate
RestTemplate restTemplate = HttpInvoker.getRestTemplate();
HttpEntity request = new HttpEntity(headers);
// 構(gòu)造execute()執(zhí)行所需要的參數(shù)。
RequestCallback requestCallback = restTemplate.httpEntityCallback(request, JSONObject.class);
ResponseExtractor<ResponseEntity<JSONObject>> responseExtractor = restTemplate.responseEntityExtractor(JSONObject.class);
// 執(zhí)行execute(),發(fā)送請求
ResponseEntity<JSONObject> response = restTemplate.execute(apiAddress + "/xxx/whitelist/check?phone=" + mobile, HttpMethod.GET, requestCallback, responseExtractor);

雖然很簡單,但是看似不可能,自己卻做到了、完成了,就很有成就感。

RestTemplate優(yōu)雅的發(fā)送Get請求

在我們的項(xiàng)目中,如果借助RestTemplate發(fā)送帶參數(shù)的Get請求,我們可以通過拼接字符串的方式將url拼接出來,比如下面這種方式:

?
1
2
String url = "http://127.0.0.1:8080/rest/get?name="+ name +"&id=" + id;
ResponseEntity<RestVO> forEntity = restTemplate.getForEntity(url, RestVO.class);

然而這種方式不太優(yōu)雅,我們還可以通過以下幾種方式發(fā)送Get請求

方式1:使用占位符

?
1
2
3
4
5
String url = "http://127.0.0.1:8080/rest/path/{name}/{id}";
Map<String, Object> params = new HashMap<>();
params.put("name", "這是name");
params.put("id", 1L);
ResponseEntity<RestVO> forEntity = restTemplate.getForEntity(url, RestVO.class, params);

Map的key要和url中的占位符一致

方式2:使用LinkedMultiValueMap和UriComponentsBuilder

?
1
2
3
4
5
6
7
8
String url = "http://127.0.0.1:8080/rest/get";
MultiValueMap<String, String> params = new LinkedMultiValueMap<>();
params.add("name", "這是name");
params.add("id", "1");
UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(url);
URI uri = builder.queryParams(params).build().encode().toUri();
ResponseEntity<RestVO> forEntity = restTemplate.getForEntity(uri, RestVO.class);
return forEntity.getBody();

方式2看起來是最優(yōu)雅的,將參數(shù)的設(shè)置和url分離。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://sizuoka.blog.csdn.net/article/details/86497531

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美国产精品一区二区三区 | 亚洲高清视频一区二区 | 久草热线| 亚洲a网| 日韩精品一区二区三区精品av | 黄色免费网| 久久夜色精品国产 | 日产精品一区二区三区在线观看 | 精品女同一区二区三区在线绯色 | 电影91久久久 | 欧美电影免费网站 | 久久这里有精品视频 | 免费一区二区三区 | 日韩成人精品在线 | 久久婷婷欧美 | 在线免费av观看 | 国产高清在线精品一区二区三区 | 日韩免费在线 | 99视频网 | 天天草天天干 | 久久aⅴ国产欧美74aaa | 欧美中文字幕在线 | 免费成人高清在线视频 | 久久精品青青大伊人av | 久久综合九色综合欧美狠狠 | 在线观看视频黄 | 日本视频免费 | 久久精品国产v日韩v亚洲 | 日韩欧美中文字幕在线观看 | 久久a视频| 日韩一区在线播放 | 中文在线日韩 | 日韩精品99久久久久中文字幕 | 精品久久一区二区 | 日韩午夜 | 国产午夜久久 | 视频一区二区三区在线观看 | 在线国产一区二区 | 久久久一区二区 | 日本中文在线 | 日韩免费视频 |