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