Spring5のRestTemplateのgetForObjectでJSONを取得するサンプルです。
(確認環境:Spring 5.3.7、JDK 11、STS 4)
目次
サンプル | RestTemplateでREST APIにアクセスしJSONを取得する |
pom.xml | |
1.起動するクラス(MainController.java) | |
2.設定ファイル(applicationContext.xml) | |
3.getでJSONを取得するクラス(CommService.java) | |
4.受信した値を格納するクラス(RestDto.java) |
RestTemplateでREST APIにアクセスしJSONを取得する
無料Webサービスのhttpbinに対してCommService.javaのRestTemplateのgetForObjectを使用してJSONデータを取得します。
また取得した一部の値をRestDtoクラスにセットします。
githubにコードがあります。
https://github.com/ut23405/spring5/tree/master/spring-getForObject
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.getでJSONを取得するクラス(CommService.java)
public <T> T getForObject(String url, Class<T> responseType, Object... uriVariables) |
package com.example.test1;
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;
public static final String URL1 = "http://httpbin.org/get";
public void getData() {
String r1 = restTemplate.getForObject(URL1, String.class);
System.out.println(r1); // 1.下記に実行結果あり
RestDto r2 = restTemplate.getForObject(URL1, 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
}
}
12行目のURLはhttpbinのURLを指しています。
15行目は、1回目のgetの送受信で16行目にJSONの全文が出力されます。(内容は以下参照)
18行目は、2回目のgetの送受信です。2つめの引数は受信するクラスで自作したRestDtoクラスに受信した値がセットされます。
19行目以降は、RestDtoの変数に格納された値を確認しています
実行結果
① 15行目の取得したJSONの文字列
{
"args": {},
"headers": {
"Accept": "text/plain, application/json, application/*+json, */*",
"Host": "httpbin.org",
"User-Agent": "Java/11.0.11",
"X-Amzn-Trace-Id": "Root=xxx"
},
"origin": "xxx.xxx.xxx.xxx",
"url": "http://httpbin.org/get"
}
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の項目ではハイフン無しにしています。
関連の記事