我正在使用swagger-codegen-maven-plugin生成api rest客户端。我正在使用resttemplate库,并且我的pom.xml配置如下所示。
<build>
<plugins>
<plugin>
<groupId>io.swagger</groupId>
<artifactId>swagger-codegen-maven-plugin</artifactId>
<version>2.3.1</version>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
<configuration>
<inputSpec>${project.basedir}/../swagger.yml</inputSpec>
<language>java</language>
<generateApis>true</generateApis>
<generateApiTests>false</generateApiTests>
<generateSupportingFiles>true</generateSupportingFiles>
<generateModelDocumentation>false</generateModelDocumentation>
<modelPackage>my.base.package.here</modelPackage>
<apiPackage>my.base.api.package.here</apiPackage>
<modelNamePrefix>MyApiPrefix</modelNamePrefix>
<configOptions>
<library>resttemplate</library>
<sourceFolder>src/gen/java</sourceFolder>
<java8>true</java8>
<dateLibrary>java8</dateLibrary>
<hideGenerationTimestamp>true</hideGenerationTimestamp>
</configOptions>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
客户端生成成功。现在,我在Spring Boot应用程序中使用此客户端,我需要配置连接超时和读取超时值。
我很惊讶地在生成的ApiClient上找不到这两个属性的设置方法。因此,我不得不提出一种使用RestTemplateBuilder来解决此问题的方法。看起来像这样:
@Configuration
public class MyApiClientConfiguration {
@Autowired
public MyApiClientConfiguration(
final RestTemplate restTemplate,
final RestTemplateBuilder restTemplateBuilder
) {
restTemplateBuilder
.setConnectTimeout(connectTimeoutValue)
.setReadTimeout(readTimeoutValue)
.configure(restTemplate);
ApiClient apiClient = new ApiClient(restTemplate);
MyApiPrefixApi.setApiClient(apiClient);
}
}
configure
方法的文档没有说太多:
配置
public T configure(T restTemplate)
使用此构建器配置提供的RestTemplate实例。
这是使用resttemplate库时配置超时的标准方法吗? 更新:我的实际实现不起作用(似乎ResttemplateBuilder自己的配置正在以错误的方式干扰自动装配的RestTemplate(我正在尝试通过构建器进行进一步配置)配置。其他库(例如jersey)生成的api客户端提供了一个setter,可以使用以下命令直接配置超时:
apiClient.setConnectTimeout(timeoutValue);
尽管无法使用configure