广告
返回顶部
首页 > 资讯 > 后端开发 > Python >springcloud 如何解决微服务之间token传递问题
  • 429
分享到

springcloud 如何解决微服务之间token传递问题

2024-04-02 19:04:59 429人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录微服务之间token传递问题服务A中FeginInterceptor 服务A添加配置文件微服务服务间调用传递tokenRequestInterceptor是feign提

微服务之间token传递问题

假设现在有A服务,B服务,外部使用RESTapi请求调用A服务,在请求头上有token字段,A服务使用完后,B服务也要使用,如何才能把token也转发到B服务呢?

这里可以使用Feign的RequestInterceptor,但是直接使用一般情况下httpservletRequest上下文对象是为空的,这里要怎么处理,请看下文。

服务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;
    } 
}

服务A配置文件中添加:application.yml 

hystrix:  
  command:  
    default:  
      execution:  
        isolation:  
          strategy: SEMAPHORE  

服务A添加配置文件

buildscript {  
    ext{  
        SpringBootVersion = '1.4.5.RELEASE' //这里对应项目中的版本    
    }  
  
    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}"  
    }  
}  

若服务B或C也想传递token,加上上述A配置即可。 

微服务服务间调用传递token

微服务间的调用通常我们使用FeignClient来实现。那么如何在调用的时候传递token来保证服务间调用的安全校验呢?

没错,我们可以配置一个拦截器。该拦截器的功能就是在请求发出去前在header中添加token。

代码如下:

@Component
public class FeignHeaderInterceptor implements RequestInterceptor {
    @Override
    public void apply(RequestTemplate template) {
        template.header(HttpHeaders.AUTHORIZATION, "token");
    }
}

RequestInterceptor是feign提供的接口

该接口只有一个方法:

public interface RequestInterceptor {
  void apply(RequestTemplate template);
}

这样被调用的服务就可以在header中拿到token来做校验了。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: springcloud 如何解决微服务之间token传递问题

本文链接: https://www.lsjlt.com/news/141574.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • springcloud 如何解决微服务之间token传递问题
    目录微服务之间token传递问题服务A中FeginInterceptor 服务A添加配置文件微服务服务间调用传递tokenRequestInterceptor是feign提...
    99+
    2022-11-13
  • Feign如何解决服务之间调用传递token
    目录解决服务之间调用传递tokenFeign有提供一个接口RequestInterceptor调用方式Feign调用服务各种坑处理编写被调用服务编写调用api编写客户端服务解决服务之...
    99+
    2022-11-13
  • feign之间传递oauth2 token的问题及解决方案
    目录feign之间传递oauth2token问题授权服务资源项目里获取当前用户oauth2feign报401的错误解决方法feign之间传递oauth2 token问题 在微服务架构...
    99+
    2022-11-13
  • Feign怎么解决服务之间调用传递token
    这篇“Feign怎么解决服务之间调用传递token”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Feign怎么解决服务之间调...
    99+
    2023-06-29
  • SpringCloud如何解决服务之间的通信问题
    目录1、如何解决服务之间的通信问题?2、如何在java代码中发起http方式请求?3、实现服务间通信的小案例4、现有RestTemplate方式通信存在的问题?5、解决RestTem...
    99+
    2022-11-12
  • SpringCloud网关(Zuul)如何给多个微服务之间传递共享参数
    目录1、使用场景解决方案1解决方案22、代码实现3、成果展现4、总结1、使用场景 因为最近项目需要国际化,但是以前国际化的语言切换是放置在未进行微服务化之前的一个独立的SpringB...
    99+
    2022-11-13
  • SpringCloud如何使用Eureka实现服务之间的传递数据
    相信大家最关心的肯定不是什么一大堆的破理论,然后还似懂非懂的,最关心得莫过于服务之间的参数传递,数据获取。 Ok,今天就告诉大家三种微服务之间传输数据的方式,分别是: 1、最基本的利...
    99+
    2022-11-12
  • 如何解决feign微服务间的文件上传报错问题
    本篇内容介绍了“如何解决feign微服务间的文件上传报错问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!A微服务调用B服务的上传文件接口报...
    99+
    2023-06-20
  • 解决feign微服务间的文件上传报错问题
    A微服务调用B服务的上传文件接口报错: the request was rejected because no multipart boundary was found spri...
    99+
    2022-11-12
  • Vue如何解决兄弟组件之间传值问题
    目录解决兄弟组件之间传值问题bus可以通过两种方式来实现各类组件间传值方法(父子、兄弟、页级)父子关系组件兄弟关系组件页级关系组件解决兄弟组件之间传值问题 vue中 父组件向子组件传...
    99+
    2022-11-13
  • 如何解决SpringCloud服务注册IP错误的问题
    这篇文章主要介绍“如何解决SpringCloud服务注册IP错误的问题”,在日常操作中,相信很多人在如何解决SpringCloud服务注册IP错误的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何解决S...
    99+
    2023-06-20
  • 如何解决基于Pinpoint对SpringCloud微服务项目实现全链路监控的问题
    这篇文章主要为大家展示了“如何解决基于Pinpoint对SpringCloud微服务项目实现全链路监控的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决基于Pinpoint对Sprin...
    99+
    2023-06-29
  • 如何解决微信小程序中视图控件与bindtap之间的问题
    这篇文章将为大家详细讲解有关如何解决微信小程序中视图控件与bindtap之间的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在微信小程序中 最常用的<view&...
    99+
    2022-10-19
  • 缓存问题:Java路径和Apache服务器之间的冲突如何解决?
    在开发过程中,我们常常需要使用缓存来提高系统的性能。在Java中,我们可以使用Java缓存API来实现缓存功能。但是,在使用缓存时,我们也会遇到一些问题,例如Java路径和Apache服务器之间的冲突。 Java路径和Apache服务器之...
    99+
    2023-07-29
    path 缓存 apache
  • 如何解决日本服务器CPU百分之百问题
    日本服务器CPU百分之百的解决方法是:先打开任务管理器,点击进程,再点击CPU选项卡找到w3wp.exe进程,然后查看它是否占用了CPU所有的资源;若是的话,则打开IIS管理器,再打开网站对应的应用程序池里面的应用属性,然后点击性能选项卡,...
    99+
    2022-10-22
  • 微服务架构如何解决应用状态的管理问题?
    随着应用的不断发展和扩展,应用状态管理问题也变得越来越复杂和困难。传统的单一应用架构难以应对多个模块和组件的管理问题,而微服务架构则为解决这些问题提供了有效的解决方案。微服务架构是一种基于一些小型服务的架构,这些服务都可以独立运行并进行相互...
    99+
    2023-05-18
    微服务架构 应用状态 管理问题
  • C#开发中如何处理分布式事务和消息传递问题及解决方法
    C#开发中如何处理分布式事务和消息传递问题及解决方法在分布式系统中,分布式事务和消息传递是常见的问题。分布式事务指的是涉及多个数据库或服务的事务,而消息传递则指的是系统中不同组件之间的异步通信。本文将介绍在C#开发中如何处理这些问题,并提供...
    99+
    2023-10-22
    分布式 传递 处理 分布式事务处理:事务 消息传递问题:消息
  • 如何解决微软和亚马逊最新服务器信息错误问题
    1. 检查来源和准确性 首先,确认错误信息的来源和准确性。确保你获取的信息来自可靠的渠道,如官方网站、技术论坛或可信赖的新闻来源。有时候,错误信息可能是由于误解、传闻或不准确的报道而产生的。 2. 查阅官方文档和支持资源 微软和亚马逊都提...
    99+
    2023-10-27
    亚马逊 微软 如何解决
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作