zuul过滤器中转发请求头
Zuul网关过滤的时候,如果不在网关过滤时转发请求头,经过网关时请求头就会丢失。
网关过滤转发请求头代码如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
@Override public Object run() throws ZuulException { RequestContext currentContext = RequestContext.getCurrentContext(); HttpServletRequest request = currentContext.getRequest(); Enumeration<String> headerNames = request.getHeaderNames(); if (headerNames != null ) { while (headerNames.hasMoreElements()) { String name = headerNames.nextElement(); String values = request.getHeader(name); currentContext.addZuulRequestHeader(name, values); } } return null ; } |
但我用 addZuulRequestHeader转发请求头却不起作用。原来是敏感请求头Authorization,Cookie,Set-Cookie默认不转发的。
解决方法一:使用别的单词,如 token、myAuthorizaion等
解决方法二:配置application.yml
1
2
3
4
5
6
7
|
zuul: routes: api-seller: path: /api/seller/** serviceId: mobileshop-api-seller-feign sensitive-headers: - Cookie,Set-Cookie,Authorization |
zuul路由转发header丢失问题
定义一个前置过滤器,获取原生request的请求头,塞到zuul转发request请求头中。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/tripleDemo/article/details/103548531