zuul轉(zhuǎn)發(fā)后服務(wù)取不到請求路徑的解決
zuul轉(zhuǎn)發(fā)后服務(wù)取不到請求路徑
問題
希望通過獲取不同的路徑中的項目名,動態(tài)設(shè)置數(shù)據(jù)源,但是經(jīng)過zuul網(wǎng)關(guān)后,在后面的服務(wù)中獲取不到請求路徑。
解決
通過Header:x-forwarded-prefix獲取
測試代碼:
@GetMapping("/a") public String a(HttpServletRequest request) { StringBuilder result = new StringBuilder(); result.append("getMethod:" + request.getMethod() + "\n\r"); result.append("getRequestURL:" + request.getRequestURL() + "\n\r"); result.append("getServletPath:" + request.getServletPath() + "\n\r"); result.append("getContextPath:" + request.getContextPath() + "\n\r"); result.append("getPathInfo:" + request.getPathInfo() + "\n\r"); result.append("---------------------------------------------------" + "\n\r"); Enumeration<String> es = request.getHeaderNames(); while (es.hasMoreElements()) { result.append(es.nextElement() + ":" + request.getHeader(es.nextElement()) + "\n\r"); } return result.toString(); }
返回結(jié)果:
路徑中標紅的地方,和x-forwarded-prefix頭部里的內(nèi)容是一樣的,所以使用request.getHeader('x-forwarded-prefix')就可以獲取到當前訪問的項目,然后做區(qū)分。
思考
推測是因為zuul轉(zhuǎn)發(fā)請求的時候用的代理,本地相當于直接訪問http://localhost:9070/a,所以就獲取不到最開始輸入的路徑,而x-forwarded-prefix這個頭部是用來記錄請求最初從瀏覽器發(fā)出時的訪問地址
zuul 地址轉(zhuǎn)發(fā)問題
最近在學(xué)習(xí)spring cloud,使用zuul過程中發(fā)現(xiàn)地址并沒轉(zhuǎn)發(fā)成功,頁面一直報錯404.
使用的Spring cloud版本為最新版Greenwich
zuul中配置文件內(nèi)容是
server: port: 8180 spring: application: name: zuul-test zuul: routes: hello: path: /hello/** url: http://localhost:9180/
期望的是當web請求http://localhost:8180/hello?name=world 時能跳轉(zhuǎn)到http://localhost:9180/hello?neam=world 打印出"hello world",然而事實上并沒有,出錯,頁面提示404.
開始以為是Spring cloud版本太高,就把純潔的微笑博客中的demo下載下來測試,發(fā)現(xiàn)依然如此。
懷疑zuul的請求是直接跳轉(zhuǎn)到http://localhost:9180/ 但是沒有加上上下文"hello"
所以將配置更改如下:
server: port: 8180 spring: application: name: zuul-test zuul: routes: hello: path: /hello/** url: http://localhost:9180/hello
請求跳轉(zhuǎn)成功。
畢竟是自己的猜測,還是需要代碼支持,所以斷點,調(diào)試源碼進入查看.
在org.springframework.cloud.netflix.zuul.filters.route.SimpleHostRoutingFilter#run方法中通過
String uri = this.helper.buildZuulRequestURI(request);
解析出uri=“”,然后通過當前類中的forward方法組織請求參數(shù)并轉(zhuǎn)發(fā).
源碼如下
重要是圖中紅框部分,如果你的轉(zhuǎn)發(fā)地址沒有帶上上下文,host.getPath()獲取的值將為"",與之前獲取的uri拼接后為"".
通過323行
buildHttpRequest(verb, uri, entity, headers, params,request);
獲取的httpRequest中的uri將會是?name=world,請求轉(zhuǎn)發(fā)地址變成http://localhost:9180/?name=world,當然會404了。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot自定義加載yml實現(xiàn)方式,附源碼解讀
這篇文章主要介紹了SpringBoot自定義加載yml實現(xiàn)方式附源碼解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03Idea Project文件目錄不見了,只剩External Libraries和imi文件的解決
這篇文章主要介紹了Idea Project文件目錄不見了,只剩External Libraries和imi文件的解決方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08JDBC數(shù)據(jù)庫連接過程及驅(qū)動加載與設(shè)計模式詳解
這篇文章主要介紹了JDBC數(shù)據(jù)庫連接過程及驅(qū)動加載與設(shè)計模式詳解,需要的朋友可以參考下2016-10-10Java?實戰(zhàn)項目之學(xué)生信息管理系統(tǒng)的實現(xiàn)流程
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實現(xiàn)學(xué)生信息管理系統(tǒng),大家可以在過程中查缺補漏,提升水平2021-11-11Spring AOP與AspectJ的對比及應(yīng)用詳解
這篇文章主要為大家介紹了Spring AOP與AspectJ的對比及應(yīng)用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02