您好,登錄后才能下訂單哦!
小編給大家分享一下如何使用springcloud+oauth2攜帶token去請求其他服務,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
攜帶該token去請求其他服務時,報出
{ "error": "invalid_token", "error_description": "Invalid access token: e5224346-ea39-49ff-bd0e-1b9aef3db1da" }
#內置有user對象的地址,才能獲取到同一個token security.oauth3.resource.user-info-uri=http://localhost:8003/api/user security.oauth3.resource.prefer-token-info=false
在springcloud 微服務中大部分是通過token來驗證用戶的,那么有個問題,假設現在有A服務,B服務,外部使用RESTApi請求調用A服務,在請求頭上有token字段,A服務使用完后,B服務也要使用,如何才能把token也轉發到B服務呢,最差的解決辦法就是吧token放到請求參數中,但是這樣第一個是明文傳輸,第二個是比較麻煩,前端每次都要加個參數。
這里可以使用Feign的RequestInterceptor,把request里的請求參數包括請求頭全部復制到feign的request里,但是直接使用一般情況下HttpServletRequest上下文對象是為空的,其實加個配置就可以解決。
hystrix: command: default: execution: isolation: strategy: SEMAPHORE #加上這個就可以獲取到HttpServletRequest thread: timeoutInMilliseconds: 10000
@Configuration public class FeginInterceptor implements RequestInterceptor { @Override public void apply(RequestTemplate requestTemplate) { try { Map<String,String> headers = getHeaders(); for(String headerName : headers.keySet()){ requestTemplate.header(headerName, headers.get(headerName)); } }catch (Exception e){ e.printStackTrace(); } } private Map<String, String> getHeaders(){ HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); Map<String, String> map = new LinkedHashMap<>(); Enumeration<String> enumeration = request.getHeaderNames(); while (enumeration.hasMoreElements()) { String key = enumeration.nextElement(); String value = request.getHeader(key); map.put(key, value); } return map; } }
若服務B或C也想傳遞token,加上上述A配置即可~
看完了這篇文章,相信你對“如何使用springcloud+oauth2攜帶token去請求其他服務”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。