springcloud?如何解決微服務(wù)之間token傳遞問(wèn)題
微服務(wù)之間token傳遞問(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ù)呢?
這里可以使用Feign的RequestInterceptor,但是直接使用一般情況下HttpServletRequest上下文對(duì)象是為空的,這里要怎么處理,請(qǐng)看下文。
服務(wù)A中FeginInterceptor
@Configuration
public class FeginInterceptor implements RequestInterceptor {
?
? ? @Override
? ? public void apply(RequestTemplate requestTemplate) {
? ? ? ? Map<String,String> headers = getHeaders(getHttpServletRequest());
? ? ? ? for(String headerName : headers.keySet()){
? ? ? ? ? ? requestTemplate.header(headerName, getHeaders(getHttpServletRequest()).get(headerName));
? ? ? ? }
? ? }
?
? ? private HttpServletRequest getHttpServletRequest() {
? ? ? ? try {
? ? ? ? ? ? return ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
? ? ? ? } catch (Exception e) {
? ? ? ? ? ? e.printStackTrace();
? ? ? ? ? ? return null;
? ? ? ? }
? ? }
?
? ? private Map<String, String> getHeaders(HttpServletRequest request) {
? ? ? ? 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ù)A配置文件中添加:application.yml
hystrix: ? ? command: ? ? ? default: ? ? ? ? execution: ? ? ? ? ? isolation: ? ? ? ? ? ? strategy: SEMAPHORE ?
服務(wù)A添加配置文件
buildscript { ?
? ? ext{ ?
? ? ? ? springBootVersion = '1.4.5.RELEASE' //這里對(duì)應(yīng)項(xiàng)目中的版本 ???
? ? } ?
??
? ? repositories { ?
? ? ? ? mavenCentral() ?
? ? } ?
? ? dependencies { ?
? ? ? ? classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}") ?
? ? ? ? classpath "io.spring.gradle:dependency-management-plugin:0.5.6.RELEASE" ?
? ? } ?
} ?
??
apply plugin: 'java' ?
apply plugin: 'org.springframework.boot' ?
apply plugin: "io.spring.dependency-management" ?
version = '0.0.1-SNAPSHOT' ?
group 'com.dounine.test' ?
??
sourceCompatibility = 1.8 ???
repositories { ?
? ? mavenLocal() ?
? ? mavenCentral() ?
} ?
??
ext { ?
? ? springCloudVersion = 'Dalston.SR2' ?
} ?
??
dependencies { ?
? ? compile('org.springframework.cloud:spring-cloud-starter-config') ?
? ? compile('org.springframework.cloud:spring-cloud-starter-eureka') ?
? ? compile('org.springframework.cloud:spring-cloud-starter-feign') ?
? ? compile group: 'org.aspectj', name: 'aspectjweaver', version: '1.8.13' ?
? ? compile('org.springframework.boot:spring-boot-starter-data-redis') ?
? ? testCompile('org.springframework.boot:spring-boot-starter-test') ?
} ?
??
dependencyManagement { ?
? ? imports { ?
? ? ? ? mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}" ?
? ? } ?
} ?若服務(wù)B或C也想傳遞token,加上上述A配置即可。
微服務(wù)服務(wù)間調(diào)用傳遞token
微服務(wù)間的調(diào)用通常我們使用FeignClient來(lái)實(shí)現(xiàn)。那么如何在調(diào)用的時(shí)候傳遞token來(lái)保證服務(wù)間調(diào)用的安全校驗(yàn)?zāi)兀?/p>
沒(méi)錯(cuò),我們可以配置一個(gè)攔截器。該攔截器的功能就是在請(qǐng)求發(fā)出去前在header中添加token。
代碼如下:
@Component
public class FeignHeaderInterceptor implements RequestInterceptor {
? ? @Override
? ? public void apply(RequestTemplate template) {
? ? ? ? template.header(HttpHeaders.AUTHORIZATION, "token");
? ? }
}RequestInterceptor是feign提供的接口
該接口只有一個(gè)方法:
public interface RequestInterceptor {
? void apply(RequestTemplate template);
}這樣被調(diào)用的服務(wù)就可以在header中拿到token來(lái)做校驗(yàn)了。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java如何比較兩個(gè)對(duì)象并獲取不相等的字段詳解
這篇文章主要給大家介紹了關(guān)于Java如何比較兩個(gè)對(duì)象并獲取不相等的字段以及JAVA判斷(獲?。﹥蓚€(gè)相同對(duì)象不同的數(shù)據(jù)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-11-11
Spring Cloud Alibaba配置多環(huán)境管理詳解與實(shí)戰(zhàn)代碼
本文通過(guò)實(shí)際案例詳細(xì)介紹了springboot配置多環(huán)境管理的使用,以及基于nacos的配置多環(huán)境管理的實(shí)踐,在實(shí)際開發(fā)中,配置多環(huán)境管理是一個(gè)很難避開的問(wèn)題,同時(shí)也是微服務(wù)治理中一個(gè)很重要的內(nèi)容,感興趣的朋友跟隨小編一起看看吧2024-06-06
springboot實(shí)現(xiàn)在工具類(util)中調(diào)用注入service層方法
這篇文章主要介紹了springboot實(shí)現(xiàn)在工具類(util)中調(diào)用注入service層方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06
java、js中實(shí)現(xiàn)無(wú)限層級(jí)的樹形結(jié)構(gòu)方法(類似遞歸)
下面小編就為大家?guī)?lái)一篇java、js中實(shí)現(xiàn)無(wú)限層級(jí)的樹形結(jié)構(gòu)方法(類似遞歸)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-11-11
詳解大數(shù)據(jù)處理引擎Flink內(nèi)存管理
Flink是jvm之上的大數(shù)據(jù)處理引擎,jvm存在java對(duì)象存儲(chǔ)密度低、full gc時(shí)消耗性能,gc存在stw的問(wèn)題,同時(shí)omm時(shí)會(huì)影響穩(wěn)定性。針對(duì)頻繁序列化和反序列化問(wèn)題flink使用堆內(nèi)堆外內(nèi)存可以直接在一些場(chǎng)景下操作二進(jìn)制數(shù)據(jù),減少序列化反序列化消耗。本文帶你詳細(xì)理解其原理。2021-05-05
springboot中用fastjson處理返回值為null的屬性值
在本篇文章里小編給大家整理的是一篇關(guān)于springboot中用fastjson處理返回值問(wèn)題詳解內(nèi)容,需要的朋友們參考下。2020-03-03
springboot跨域如何設(shè)置SameSite的實(shí)現(xiàn)
這篇文章主要介紹了springboot跨域如何設(shè)置SameSite的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05
Java命令行運(yùn)行錯(cuò)誤之找不到或無(wú)法加載主類問(wèn)題的解決方法
這篇文章主要給大家介紹了關(guān)于Java命令行運(yùn)行錯(cuò)誤之找不到或無(wú)法加載主類問(wèn)題的解決方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-01-01

