我在服务 A 和 B 前使用 Netflix Zuul 代理。
如何让 Zuul 代理根据传入请求中的 HTTP 标头在 A 和 B 的路由之间进行选择?
我有一个后端服务,它接受授权标头来验证访问。我使用 Spring cloud zuul 创建了一个网关服务,并将请求路由到后端服务。
网关服务本身受 OAuth2 保护,并接受授权标头来验证访问。现在,一旦请求授权网关服务,网关服务将充当客户端,使用其 clientid、secret 和后端服务资源 ID 在标头中发送更新的访问令牌。由于它必须发送授权标头,因此我尝试更新请求中的授权标头,但它采用以下两种方式。
ctx = RequestContext.getCurrentContext();
ctx.addZuulRequestHeader("Authorization", accessToken);
Run Code Online (Sandbox Code Playgroud)
使用上面的代码,它添加了授权标头,但将其添加到后端服务无法识别的 zuul 标头中。
我创建了一个包装器来修改请求对象,但它不起作用
public class RequestWrapper extends HttpServletRequestWrapper
{
private final Map<String, String[]> modifiableParameters;
private Map<String, String[]> allParameters = null;
public RequestWrapper(final HttpServletRequest request,
final Map<String, String[]> additionalParams)
{
super(request);
modifiableParameters = new TreeMap<String, String[]>();
modifiableParameters.putAll(additionalParams);
}
@Override
public String getParameter(final String name)
{
String[] strings = getParameterMap().get(name);
if (strings != null)
{
return strings[0];
}
return super.getParameter(name);
}
@Override
public Map<String, …Run Code Online (Sandbox Code Playgroud)