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