Voorbeeld van Spring RestTemplate

Spring RestTemplate biedt een handige manier om RESTful web services te testen.

Spring RestTemplate

  • De Spring RestTemplate-klasse maakt deel uit van spring-web, geïntroduceerd in Spring 3.
  • We kunnen RestTemplate gebruiken om op HTTP gebaseerde restful web services te testen, het ondersteunt echter geen HTTPS-protocol.
  • De RestTemplate-klasse biedt overbelaste methoden voor verschillende HTTP-methoden, zoals GET, POST, PUT, DELETE, enzovoort.

Voorbeeld van Spring RestTemplate

Laten we eens kijken naar een voorbeeld van Spring RestTemplate waar we REST-webdiensten zullen testen die zijn gemaakt in het artikel Spring Data JPA. Onderstaande tabel illustreert de URIs die worden ondersteund door deze REST-webdienst. .tg {border-collapse:collapse;border-spacing:0;border-color:#999;} .tg td{font-family:Arial, sans-serif;font-size:14px;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:#999;color:#444;background-color:#F7FDFA;} .tg th{font-family:Arial, sans-serif;font-size:14px;font-weight:normal;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;border-color:#999;color:#fff;background-color:#26ADE4;} .tg .tg-baqh{text-align:center;vertical-align:top} .tg .tg-yw4l{vertical-align:top}

URI HTTP Method Description
/springData/person GET Get all persons from database
/springData/person/{id} GET Get person by id
/springData/person POST Add person to database
/springData/person PUT Update person
/springData/person/{id} DELETE Delete person by id

Laten we beginnen met het maken van ons Rest-clientproject om deze webdiensten te testen. Onderstaande afbeelding toont ons uiteindelijke voorbeeldproject van Spring RestTemplate.

Spring RestTemplate Maven-afhankelijkheden

We hebben de afhankelijkheden spring-core en spring-context nodig voor het Spring-framework. Daarna hebben we het artefact spring-web nodig dat de klasse RestTemplate bevat. We hebben ook jackson-mapper-asl nodig voor Spring JSON-ondersteuning via de Jackson-API.

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="https://maven.apache.org/POM/4.0.0" xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="https://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>com.journaldev.spring</groupId>
	<artifactId>SpringRestTemplate</artifactId>
	<version>1.0-SNAPSHOT</version>
	<properties>
		<spring.framework>4.3.0.RELEASE</spring.framework>
		<spring.web>3.0.2.RELEASE</spring.web>
		<serializer.version>2.8.1</serializer.version>
	</properties>
	<dependencies>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-core</artifactId>
			<version>${spring.framework}</version>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-context</artifactId>
			<version>${spring.framework}</version>
		</dependency>
		<dependency>
			<groupId>org.codehaus.jackson</groupId>
			<artifactId>jackson-mapper-asl</artifactId>
			<version>1.9.4</version>
		</dependency>
		<dependency>
			<groupId>org.springframework</groupId>
			<artifactId>spring-web</artifactId>
			<version>${spring.web}</version>
		</dependency>
	</dependencies>
</project>

Spring Configuration Class

We moeten een Spring bean definiëren voor de RestTemplate-klasse, dat wordt gedaan in de klasse AppConfig.

package com.journaldev.spring.config;

import org.codehaus.jackson.map.ObjectMapper;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.converter.json.MappingJacksonHttpMessageConverter;
import org.springframework.web.client.RestTemplate;

@Configuration
@ComponentScan("com.journaldev.spring")
public class AppConfig {

	@Bean
	RestTemplate restTemplate() {
		RestTemplate restTemplate = new RestTemplate();
		MappingJacksonHttpMessageConverter converter = new MappingJacksonHttpMessageConverter();
		converter.setObjectMapper(new ObjectMapper());
		restTemplate.getMessageConverters().add(converter);
		return restTemplate;
	}
}

Merk op dat RestTamplate een MessageConverter gebruikt en we moeten deze eigenschap instellen in de RestTemplate-bean. In ons voorbeeld gebruiken we MappingJacksonHttpMessageConverter om gegevens op te halen uit JSON-formaat.

Modelklasse

Aangezien we proberen JSON om te zetten die wordt geretourneerd door onze webservice naar een Java-object met behulp van Jackson Mapper, moeten we de modelklasse hiervoor maken. Let op dat deze modelklasse erg lijkt op de modelklasse die wordt gebruikt in de webservice, behalve dat we hier geen JPA-annotaties nodig hebben.

package com.journaldev.spring.model;

public class Person {

	private Long id;

	private Integer age;

	private String firstName;

	private String lastName;

	public Person() {
	}

	public Long getId() {
		return id;
	}

	public void setId(Long id) {
		this.id = id;
	}

	public Integer getAge() {
		return age;
	}

	public void setAge(Integer age) {
		this.age = age;
	}

	public String getFirstName() {
		return firstName;
	}

	public void setFirstName(String firstName) {
		this.firstName = firstName;
	}

	public String getLastName() {
		return lastName;
	}

	public void setLastName(String lastName) {
		this.lastName = lastName;
	}

	@Override
	public String toString() {
		return "Person{" + "id=" + id + ", age=" + age + ", firstName='" + firstName + '\'' + ", lastName='" + lastName
				+ '\'' + '}';
	}
}

Klasse Spring RestTemplate-client

Het laatste stap is het maken van de clientklassen die de RestTemplate-bean zullen gebruiken die hierboven is gedefinieerd.

package com.journaldev.spring.config;

import java.util.List;

import org.springframework.http.HttpStatus;

import com.journaldev.spring.model.Person;

public interface PersonClient {
	List<Person> getAllPerson();

	Person getById(Long id);

	HttpStatus addPerson(Person person);

	void updatePerson(Person person);

	void deletePerson(Long id);
}
package com.journaldev.spring.config;

import java.util.Arrays;
import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;

import com.journaldev.spring.model.Person;

@Service
public class PersonClientImpl implements PersonClient {

	@Autowired
	RestTemplate restTemplate;

	final String ROOT_URI = "https://localhost:8080/springData/person";

	public List<Person> getAllPerson() {
		ResponseEntity<Person[]> response = restTemplate.getForEntity(ROOT_URI, Person[].class);
		return Arrays.asList(response.getBody());

	}

	public Person getById(Long id) {
		ResponseEntity<Person> response = restTemplate.getForEntity(ROOT_URI + "/"+id, Person.class);
		return response.getBody();
	}

	public HttpStatus addPerson(Person person) {
		ResponseEntity<HttpStatus> response = restTemplate.postForEntity(ROOT_URI, person, HttpStatus.class);
		return response.getBody();
	}

	public void updatePerson(Person person) {
		restTemplate.put(ROOT_URI, person);
	}

	public void deletePerson(Long id) {
		restTemplate.delete(ROOT_URI + id);

	}
}

De code spreekt voor zich, we roepen RestTemplate-methoden aan op basis van de URI en de HTTP-methode en door het juiste verzoekobject door te geven indien nodig.

Klasse Spring RestTemplate-test

Het is tijd om ons Spring RestTemplate-voorbeeldproject te testen, de onderstaande klasse laat zien hoe je RestTemplate-methoden kunt gebruiken op de Spring-manier.

package com.journaldev.spring;

import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.http.HttpStatus;

import com.journaldev.spring.config.AppConfig;
import com.journaldev.spring.config.PersonClient;
import com.journaldev.spring.model.Person;

public class Main {

	public static void main(String[] args) {
		AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(AppConfig.class);

		PersonClient client = applicationContext.getBean(PersonClient.class);

		System.out.println("Getting list of all people:");

		for (Person p : client.getAllPerson()) {
			System.out.println(p);
		}

		System.out.println("\nGetting person with ID 2");

		Person personById = client.getById(2L);

		System.out.println(personById);

		System.out.println("Adding a Person");
		Person p = new Person();
		p.setAge(50);
		p.setFirstName("David");
		p.setLastName("Blain");
		HttpStatus status = client.addPerson(p);
		System.out.println("Add Person Response = " + status);

		applicationContext.close();
	}
}

Als ik het bovenstaande programma tegen mijn lokale configuratie uitvoer, krijg ik de volgende uitvoer.

Getting list of all people:
Person{id=2, age=30, firstName='Oksi', lastName=' Bahatskaya'}
Person{id=1, age=30, firstName='Vlad', lastName='Mateo'}

Getting person with ID 2
Person{id=2, age=30, firstName='Oksi', lastName=' Bahatskaya'}
Adding a Person
Add Person Response = 201

Hieronder zie je de gegevens van de databasetabel van de webservice vóór en na het uitvoeren van het bovenstaande programma. Zoals je kunt zien, komt de uitvoer van het programma overeen met de voorbeeldgegevens in de tabel. Dat is alles voor het Spring RestTemplate-voorbeeld, je kunt het project downloaden vanaf onderstaande link.

Download Voorbeeldproject Spring RestTemplate

Referentie: API-documentatie

Source:
https://www.digitalocean.com/community/tutorials/spring-resttemplate-example