13

我正在尝试向受 IAM 访问策略保护的AWS Elasticsearch域发出 HTTP 请求。我需要签署这些请求才能获得 AWS 的授权。我正在使用Jest,而后者又使用Apache HttpComponents Client

这似乎是一个常见的用例,但我找不到我应该怎么做才能让 Jest 签署所有请求。

4

2 回答 2

13

我想我找到了!:)

这个项目似乎完全符合我的要求:aws-signing-request-interceptor,描述为“对 AWS 的请求进行签名的 Apache 客户端的请求拦截器。最初创建是为了使用 Jest 客户端支持 AWS 的 Elasticsearch 服务。” .

编辑:我分叉了项目以满足我的需求(Java 7,临时 STS 凭证),它运行良好。

这是一个使用示例(此处没有 STS 临时凭证):

String region = "us-east-1";
String service = "es";
String url = "???"; // put the AWS ElasticSearch endpoint here

DefaultAWSCredentialsProviderChain awsCredentialsProvider = new DefaultAWSCredentialsProviderChain();
final AWSSigner awsSigner = new AWSSigner(awsCredentialsProvider, region, service, () -> new LocalDateTime(DateTimeZone.UTC));

JestClientFactory factory = new JestClientFactory() {
    @Override
    protected HttpClientBuilder configureHttpClient(HttpClientBuilder builder) {
        builder.addInterceptorLast(new AWSSigningRequestInterceptor(awsSigner));
        return builder;
    }
};
factory.setHttpClientConfig(new HttpClientConfig.Builder(url)
        .multiThreaded(true)
        .build());
JestClient client = factory.getObject();
于 2015-11-17T17:08:10.497 回答
2

这在异步请求的情况下不起作用。

更新:

忽略我之前的评论。在为异步请求添加拦截器后它也可以工作:

final AWSSigningRequestInterceptor requestInterceptor = new AWSSigningRequestInterceptor(awsSigner);
            factory = new JestClientFactory() {
                @Override
                protected HttpClientBuilder configureHttpClient(HttpClientBuilder builder) {
                    builder.addInterceptorLast(requestInterceptor);
                    return builder;
                }
                @Override
                protected HttpAsyncClientBuilder configureHttpClient(HttpAsyncClientBuilder builder) {
                    builder.addInterceptorLast(requestInterceptor);
                    return builder;
                }
            };
于 2017-04-21T19:06:18.627 回答