上节做了个hello Spring Web Service.这次正好可以进行测试下。本节花5分钟做这样的一个实例。
自动去访问某个接口如下,然后用日志的方式显示返回的结果。
Spring也提供了一个接口:https://gturnquist-quoters.cfapps.io/api/random
{"type":"success","value":{"id":7,"quote":"Theet."}}
步骤一:创建一个SpringWeb工程。
步骤二:创建2个class: /spring-web-serivce-Consumingdemo-1/src/main/java/com/dongyuexample/Value.java
package com.dongyuexample;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
@JsonIgnoreProperties(ignoreUnknown = true)
public class Value {
private Long id;
private String quote;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getQuote() {
return quote;
}
public void setQuote(String quote) {
this.quote = quote;
}
@Override
public String toString() {
return "Value [id=" + id + ", quote=" + quote + "]";
}
public Value() {
}
}
步骤二:创建2个class:/spring-web-serivce-Consumingdemo-1/src/main/java/com/dongyuexample/Quote.java
package com.dongyuexample;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
@JsonIgnoreProperties(ignoreUnknown = true)
public class Quote {
private String type;
private Value value;
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
public Value getValue() {
return value;
}
public void setValue(Value value) {
this.value = value;
}
@Override
public String toString() {
return "Quote [type=" + type + ", value=" + value + "]";
}
}
执行类:/spring-web-serivce-Consumingdemo-1/src/main/java/com/dongyuexample/SpringWebSerivceConsumingdemo1Application.java
package com.dongyuexample;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.client.RestTemplateBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@SpringBootApplication
public class SpringWebSerivceConsumingdemo1Application {
private static final Logger log = LoggerFactory.getLogger(SpringWebSerivceConsumingdemo1Application.class) ;
public static void main(String[] args) {
// A logger, to send output to the log (the console, in this example).
//
// A RestTemplate, which uses the Jackson JSON processing library to process the incoming data.
//
// A CommandLineRunner that runs the RestTemplate (and, consequently, fetches our quotation) on startup.
//
SpringApplication.run(SpringWebSerivceConsumingdemo1Application.class, args);
}
@Bean
public RestTemplate restTemplate(RestTemplateBuilder builder) {
return builder.build();
}
@Bean
public CommandLineRunner run(RestTemplate restTemplate) throws Exception {
return args->{
Quote quote = restTemplate.getForObject(
"https://gturnquist-quoters.cfapps.io/api/random",
Quote.class);
log.info(quote.toString());
System.out.println(">>>>>>>>>>>>>>>服务启动执行 111111 <<<<<<<<<<<<<");
};
}
}