在MicroProfile REST客户端中设置基本身份验证 [英] Setting basic auth in microprofile rest client
本文介绍了在MicroProfile REST客户端中设置基本身份验证的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个服务,它为其服务公开了许多JAX-RS接口。我现在想使用这些接口来连接服务。我正在使用Quarkus,这意味着我正在使用MicroProfile REST客户端。因为我已经有了jaxars接口,所以使用@RegisterRestClient方法实际上并不可行。相反,我使用的是RestClientBuilder。
MyService client = RestClientBuilder.newBuilder()
.baseUri(URI.create("https://localhost:8080"))
.build(MyService.class);
我遇到的问题是身份验证。我需要访问的服务被锁定在基本身份验证之后。我找到的所有针对微配置文件REST客户端的指南都是this的变体,其中的解决方案是添加一个headerparam。然而,这是不可能的,因为我已经预制了接口,并且复制粘贴整个内容来添加Header参数确实是我宁愿避免的事情。
还应该提到的是,我尝试了@Provider筛选器来设置标头,但我似乎想不出如何使用该方法仅针对单个REST客户端,并且我有几个。
所以:如何使用微配置文件REST客户端在不影响JAX-RS接口本身的情况下设置基本身份验证?
推荐答案
您应该能够在MyService
上使用@ClientHeaderParam
批注。
类似于:
@Path("/my")
@ClientHeaderParam(name = "Authorization", value = "{lookupAuth}")
public interface MyService {
default String lookupAuth() {
return "Basic " +
Base64.getEncoder().encodeToString("someuser:somepass".getBytes());
}
}
有关详细信息,请参阅this
如果无法修改界面,您有两种选择:
- 创建扩展此批注所用接口的接口:
@ClientHeaderParam(name = "Authorization", value = "{lookupAuth}")
public interface MyServiceWrapper extends MyService {
default String lookupAuth() {
return "Basic " + Base64.getEncoder().encodeToString("someuser:somepass".getBytes());
}
}
- 创建填充
Authorization
头的ClientRequestFilter
:
@Priority(Priorities.AUTHENTICATION)
public class BasicRequestFilter implements ClientRequestFilter {
@Override
public void filter(ClientRequestContext requestContext) throws IOException {
requestContext.getHeaders().add(HttpHeaders.AUTHORIZATION, getAccessToken());
}
private String getAccessToken() {
return "Basic " + Base64.getEncoder().encodeToString("someuser:somepass".getBytes());
}
}
并注册筛选器,例如以编程方式:
MyService client = RestClientBuilder.newBuilder()
.register(BasicRequestFilter.class)
.baseUri(URI.create("https://localhost:8080"))
.build(MyService.class);
这篇关于在MicroProfile REST客户端中设置基本身份验证的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文