Spring postForObjectでJSONを取得する(POST)

Spring5のRestTemplateのpostForObjectでJSONを取得するサンプルです。
(確認環境:Spring 5.3.7、JDK 11、STS 4)

目次

サンプル postForObjectでREST APIにアクセスしJSONを取得する
  pom.xml
  1.起動するクラス(MainController.java)
  2.設定ファイル(applicationContext.xml)
  3.POSTでJSONを取得するクラス(CommService.java)
  4.受信した値を格納するクラス(RestDto.java)

postForObjectでREST APIにアクセスしJSONを取得する

無料Webサービスのhttpbinに対してCommService.javaのRestTemplateのpostForObjectを使用してPOSTを行いJSONデータを取得します。

また取得した一部の値をRestDtoクラスにセットします。

githubにコードがあります。
https://github.com/ut23405/spring5/tree/master/spring-postForObject

pom.xml

以下のコードをpom.xmlの<project>の<dependencies>タグ内に貼り付けます。

		<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind -->
		<dependency>
			<groupId>com.fasterxml.jackson.core</groupId>
			<artifactId>jackson-databind</artifactId>
			<version>2.12.4</version>
		</dependency>
		<!-- https://mvnrepository.com/artifact/org.springframework/spring-web -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-web</artifactId>
			<version>5.3.8</version>
		</dependency>
		<!-- https://mvnrepository.com/artifact/org.springframework/spring-context -->
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-context</artifactId>
			<version>5.3.7</version>
		</dependency>

4行目のjackson-databindは、JSONとJavaオブジェクトの変換をします。
10行目のspring-webは、RestTemplateで使用します。
16行目のspring-contextは、@ComponentScanや@Componentで使用します。

1.起動するクラス(MainController.java)

package com.example.test1;

import org.springframework.context.support.ClassPathXmlApplicationContext;

public class MainController {
	public static void main(String[] args) {
		ClassPathXmlApplicationContext context = 
				new ClassPathXmlApplicationContext("applicationContext.xml");
		CommService cs = context.getBean(CommService.class);
		cs.getData();
		context.close();
	}
}

CommServiceクラスのメソッドを使用して通信を行いJSONを取得します。

2.設定ファイル(applicationContext.xml)

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:context="http://www.springframework.org/schema/context"
	xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context.xsd">

	<bean id="restTemplate" class="org.springframework.web.client.RestTemplate"></bean>
	<context:component-scan base-package="com.example.test1" />
	
	<bean id="clientHttpRequestFactory"
		class="org.springframework.http.client.SimpleClientHttpRequestFactory">
		<property name="connectTimeout" value="3000" />
		<property name="readTimeout" value="3000" />
	</bean>
</beans>

10行目は、RestTemplateをDIコンテナに登録しています。このサンプルではidの値は使用していません。
11行目のcomponentScanは、対象のパッケージ配下にある@Componentが付与されたクラスを探してBeanとしてDIコンテナに登録します。CommServiceで使用します。
15行目は、サーバとの接続タイムアウトの設定時間です。単位はミリ秒。
16行目は、レスポンスデータの読み込みタイムアウト時間です。単位はミリ秒。

3.POSTでJSONを取得するクラス(CommService.java)

public <T> T postForObject(String url, @Nullable Object request, Class<T> responseType,Object... uriVariables)
package com.example.test1;

import java.util.HashMap;
import java.util.Map;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.client.RestTemplate;

@Component
public class CommService {
	@Autowired
	RestTemplate restTemplate;
	
	private static final String URL2 = "http://httpbin.org/post";

	public void getData() {
		String r1 = restTemplate.postForObject(URL2, null, String.class);
		System.out.println(r1); // 1.下記に実行結果あり

		RestDto r2 = restTemplate.postForObject(URL2, null, RestDto.class);
		System.out.println(r2.getHeaders().getAccept());// application/json, application/*+json
		System.out.println(r2.getHeaders().getUserAgent());// Java/11.0.11
		System.out.println(r2.getHeaders().getHost());// httpbin.org
		
		Map<String, String> color = new HashMap<>();
		color.put("a", "red");
		color.put("b", "blue");
		String r3 = restTemplate.postForObject(URL2, color, String.class);
		System.out.println(r3); // 2.下記に実行結果あり
	}
}

15行目のURLはhttpbinのURLを指しています。
18行目は、1回目のPOSTの送受信で14行目にJSONの全文が出力されます。(内容は以下参照)
21行目は、2回目のPOSTの送受信です。2つめの引数は受信するクラスで自作したRestDtoクラスに受信した値がセットされます。
22行目以降は、RestDtoの変数に格納された値を確認しています。
29行目の値の送信は、postForObjectメソッドの2つめの引数にクラスのインスタンスをセットします。

実行結果

 19行目の取得したJSONの文字列

{
  "args": {}, 
  "data": "", 
  "files": {}, 
  "form": {}, 
  "headers": {
    "Accept": "text/plain, application/json, application/*+json, */*", 
    "Content-Length": "0", 
    "Content-Type": "application/x-www-form-urlencoded", 
    "Host": "httpbin.org", 
    "User-Agent": "Java/11.0.11", 
    "X-Amzn-Trace-Id": "Root=1-61c73499-275b5faf0d19db5134bcceab"
  }, 
  "json": null, 
  "origin": "xxx.xxx.xxx.xxx", 
  "url": "http://httpbin.org/post"
}

 

 30行目の取得したJSONの文字列

{
  "args": {}, 
  "data": "{\"a\":\"red\",\"b\":\"blue\"}", 
  "files": {}, 
  "form": {}, 
  "headers": {
    "Accept": "text/plain, application/json, application/*+json, */*", 
    "Content-Length": "22", 
    "Content-Type": "application/json", 
    "Host": "httpbin.org", 
    "User-Agent": "Java/11.0.11", 
    "X-Amzn-Trace-Id": "Root=xxx"
  }, 
  "json": {
    "a": "red", 
    "b": "blue"
  }, 
  "origin": "xxx.xxx.xxx.xxx", 
  "url": "http://httpbin.org/post"
}

3行目は、送信した値がセットされています。

 

4.受信した値を格納するクラス(RestDto.java)

package com.example.test1;

public class RestDto {
	private Headers headers;
	private String url;
	
	public Headers getHeaders() {
		return headers;
	}
	public String getUrl() {
		return url;
	}
}

4行目は、JSONのオブジェクトに対する項目でクラスです。

Headers.java

上記4行目のクラスです。

package com.example.test1;

import com.fasterxml.jackson.annotation.JsonProperty;

public class Headers {
	@JsonProperty("Accept")
	private String Accept;
	@JsonProperty("Host")
	private String Host;
	@JsonProperty("User-Agent")
	private String UserAgent;
	
	public String getAccept() {
		return Accept;
	}
	public String getHost() {
		return Host;
	}
	public String getUserAgent() {
		return UserAgent;
	}
}

10行目は、JSONにハイフンがありますがJavaではエラーになるので@JsonPropertyではハイフンあり、Javaの項目ではハイフン無しにしています。

関連の記事

Spring5 MyBatisでselectするサンプル(XML)

△上に戻る