SpringBoot 中文手册 --Part IV --33 调用REST服务

本文介绍如何使用Spring Boot中的RestTemplateBuilder配置RestTemplate实例来调用远程REST服务。包括通过RestTemplateBuilder进行基本配置、使用RestTemplateCustomizer进行更广泛的应用程序范围定制,以及创建自定义RestTemplateBuilder的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文翻译自 https://docs.spring.io/spring-boot/docs/1.5.7.RELEASE/reference/htmlsingle/#boot-features-restclient

33. 调用REST 服务

你的应用如果需要调用远程的REST服务,你可以使用Spring框架的RestTemplate类。由于RestTemplate实例经常需要在使用前定制,所以Spring Boot不提供任何单一自动配置的RestTemplatebean。她所做的是自动配置一个RestTemplateBuilder用于在需要RestTemplate实例时创建一个RestTemplate实例。自动配置的RestTemplateBuilder将确保合理的HttpMessageConverters应用于RestTemplate实例。

这是一个经典例子:

@Service
public class MyBean {

    private final RestTemplate restTemplate;

    public MyBean(RestTemplateBuilder restTemplateBuilder) {
        this.restTemplate = restTemplateBuilder.build();
    }

    public Details someRestCall(String name) {
        return this.restTemplate.getForObject("/{name}/details", Details.class, name);
    }

}

Note | RestTemplateBuilder包含许多有用的方法,可以用来快速配置RestTemplate 。例如,你可以使用 buikder.basicAuthorization("user","password").build()来增加BASIC认证支持。

33.1 RestTemplate 定制

对RestTemplate定制有三种主要方法,这取决于您对定制的应用范围。

为了尽可能缩小任何自定义的范围,注入自动配置的RestTemplateBuilder然后按需调用其方法。每个方法调用返回一个新的RestTemplateBuilder实例,因此自定义只会影响构建器的使用。

为了是应用程序范围更广,可以使用一个附加定制的RestTemplateCustomizerbean。所有这些bean豆浆自动注册到自动配置的RestTemplateBuilder中,并将应用于使用它构建的任何模板。

下面是一个定制器的例子,它为192.168.0.5以外的所有主机配置代理的使用:

static class ProxyCustomizer implements RestTemplateCustomizer {

    @Override
    public void customize(RestTemplate restTemplate) {
        HttpHost proxy = new HttpHost("proxy.example.com");
        HttpClient httpClient = HttpClientBuilder.create()
                .setRoutePlanner(new DefaultProxyRoutePlanner(proxy) {

                    @Override
                    public HttpHost determineProxy(HttpHost target,
                            HttpRequest request, HttpContext context)
                                    throws HttpException {
                        if (target.getHostName().equals("192.168.0.5")) {
                            return null;
                        }
                        return super.determineProxy(target, request, context);
                    }

                }).build();
        restTemplate.setRequestFactory(
                new HttpComponentsClientHttpRequestFactory(httpClient));
    }

}

最后,最极端(也是很少使用的)选项是创建自己的RestTemplateBuilderbean。这将关闭RestTemplateBuilder的自动配置,并阻止使用任何的RestTemplateCustomizerbeans。

### 微信公众号与服务号的功能和用途区别 #### 功能差异 在功能方面,订阅号和服务号存在显著的不同。对于未经过认证的订阅号而言,无法连接到第三方链接,除非涉及小程序;而未经认证的服务号则可以连接至第三方链接[^1]。 #### 适用场景 当创建者的目的是提供特定的服务,在不具备认证资格的前提下应优先考虑选择服务号。相反,如果主要意图是以发布文章的形式来进行推广,则订阅号会是一个更为合适的选择[^2]。 #### 发展历程中的变化 自微信公众号于2012年底推出以来,经历了多次更新和发展阶段。最初仅有的基础版本逐渐演变为包含多种类型的平台体系——即后来增加的企业号以及持续改进后的现有形态。这些演变使得当前环境下微信公众账号的选择更加多样化,并且允许运营人员依据实际需求做出最佳决策[^3]。 #### 技术支持层面 值得注意的是,在涉及到技术集成或自动化交互等功能实现上,无论是哪种类型的公众账号都离不开`access_token`这一重要凭证。它作为访问API接口的关键参数之一,在整个应用开发过程中扮演着不可或缺的角色: ```python import requests def get_access_token(appid, secret): url = f"https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={appid}&secret={secret}" response = requests.get(url).json() return response['access_token'] ``` 此函数用于获取`access_token`,它是发起任何HTTP请求给微信服务器的前提条件[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值