使用springcloud+oauth2攜帶token去請(qǐng)求其他服務(wù)
springcloud+oauth2攜帶token去請(qǐng)求其他服務(wù)
當(dāng)從oauth2服務(wù)中獲取到了token后
攜帶該token去請(qǐng)求其他服務(wù)時(shí),報(bào)出
{
"error": "invalid_token",
"error_description": "Invalid access token: e5224346-ea39-49ff-bd0e-1b9aef3db1da"
}
需要在當(dāng)前服務(wù)的配置文件配置
#內(nèi)置有user對(duì)象的地址,才能獲取到同一個(gè)token security.oauth2.resource.user-info-uri=http://localhost:8003/api/user security.oauth2.resource.prefer-token-info=false
springcloud 微服務(wù)之間傳遞token
在springcloud 微服務(wù)中大部分是通過(guò)token來(lái)驗(yàn)證用戶的,那么有個(gè)問(wèn)題,假設(shè)現(xiàn)在有A服務(wù),B服務(wù),外部使用RESTApi請(qǐng)求調(diào)用A服務(wù),在請(qǐng)求頭上有token字段,A服務(wù)使用完后,B服務(wù)也要使用,如何才能把token也轉(zhuǎn)發(fā)到B服務(wù)呢,最差的解決辦法就是吧token放到請(qǐng)求參數(shù)中,但是這樣第一個(gè)是明文傳輸,第二個(gè)是比較麻煩,前端每次都要加個(gè)參數(shù)。
這里可以使用Feign的RequestInterceptor,把request里的請(qǐng)求參數(shù)包括請(qǐng)求頭全部復(fù)制到feign的request里,但是直接使用一般情況下HttpServletRequest上下文對(duì)象是為空的,其實(shí)加個(gè)配置就可以解決。
1、服務(wù)A中 application.yml 加入如下配置
hystrix:
command:
default:
execution:
isolation:
strategy: SEMAPHORE #加上這個(gè)就可以獲取到HttpServletRequest
thread:
timeoutInMilliseconds: 10000
2、服務(wù)A中加入 FeginInterceptor
@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;
}
}
若服務(wù)B或C也想傳遞token,加上上述A配置即可~
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot整合Redis實(shí)現(xiàn)高并發(fā)數(shù)據(jù)緩存的示例講解
這篇文章主要介紹了SpringBoot整合Redis實(shí)現(xiàn)高并發(fā)數(shù)據(jù)緩存,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03
Java實(shí)現(xiàn)斗地主最簡(jiǎn)代碼實(shí)例
在本篇文章里小編給各位分享的是關(guān)于Java實(shí)現(xiàn)斗地主最簡(jiǎn)代碼實(shí)例,有興趣的朋友們可以參考下。2020-05-05
Mybatis的mapper.xml中if標(biāo)簽test判斷的用法說(shuō)明
這篇文章主要介紹了Mybatis的mapper.xml中if標(biāo)簽test判斷的用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
Java RocketMQ 路由注冊(cè)與刪除的實(shí)現(xiàn)
這篇文章主要介紹了Java RocketMQ 路由注冊(cè)與刪除的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
一文帶你掌握J(rèn)ava?Future模式的靈活應(yīng)用
Future模式,簡(jiǎn)單來(lái)說(shuō),就是一種能夠管理異步操作的方式,它可以讓咱們的程序在執(zhí)行一個(gè)耗時(shí)任務(wù)的同時(shí),還能繼續(xù)做其他事情,下面我們就來(lái)看看Future模式的具體應(yīng)用吧2024-01-01
Mybatis-plus多租戶項(xiàng)目實(shí)戰(zhàn)進(jìn)階指南
多租戶是一種軟件架構(gòu)技術(shù),在多用戶的環(huán)境下共有同一套系統(tǒng),并且要注意數(shù)據(jù)之間的隔離性,下面這篇文章主要給大家介紹了關(guān)于Mybatis-plus多租戶項(xiàng)目實(shí)戰(zhàn)進(jìn)階的相關(guān)資料,需要的朋友可以參考下2022-02-02
Java創(chuàng)建樹(shù)形結(jié)構(gòu)算法實(shí)例代碼
本篇文章主要介紹了Java創(chuàng)建樹(shù)形結(jié)構(gòu)算法實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-01-01
java實(shí)例方法被覆蓋,靜態(tài)方法被隱藏Explain(詳解)
下面小編就為大家?guī)?lái)一篇java實(shí)例方法被覆蓋,靜態(tài)方法被隱藏Explain(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05

