spring cloud nacos feign服务调用携带jwtToken

之前都是用的springclou是eureka,现在使用nacos作为注册发现中心,同样feign调用的使用过程中踩过一些坑。

1.声明式调用

feign使用具体详见spring cloud alibaba教程:如何使用nacos服务注册和发现 - 方志朋的博客

2.服务之间接口调用有的需要token之类的校验

理论上只需要在调用方的请求的header中加入token就可以了,具体token获取还是生成需要调用方自己负责。举个例子:业务系统调用权限系统的角色权限接口时需要token,我们可以从request中获取到的token进而放到feign的调用中即可。下边看操作!

@Configuration
public class FeignConfig implements RequestInterceptor {
    @Override
    public void apply(RequestTemplate requestTemplate) {
        // 获取当前请求
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        // 获取request
        HttpServletRequest request = attributes.getRequest();
        // 获取Header中的tokenValue
        String token = request.getHeader("Authorization");
        //这里转换一下可能postman请求过来的会有"Bearer "
        String jwtToken = token.replace("Bearer ", "");
        // 注入Feign的请求中,这里header中token的key需要和被调用方一致
        requestTemplate.header("Authorization", jwtToken);
    }
}

然后再在声明式调用的接口上增加此configuration

@FeignClient(name = "k_man-api-test", configuration = FeignConfig.class)
public interface CpFeign {

    /**
     * 根据adminId获取Admin权限等信息
     */
    @GetMapping("/admin/personActions/{id}")
    AdminVO getAdminInfoList(@PathVariable("id") Long id);

}

到此结束被调用方在拦截器中即可获取header中的token

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Spring Boot中使用jwt.io库来解析JWT,您需要按照以下步骤进行操作: 1. 在pom.xml中引入JWT库的依赖: ```xml <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>0.9.0</version> </dependency> ``` 引用 2. 创建一个工具类来处理JWT的解析: ```java import io.jsonwebtoken.Claims; import io.jsonwebtoken.Jwts; public class JwtUtils { public static Claims parseJwt(String jwtToken, String secretKey) { return Jwts.parser() .setSigningKey(secretKey) .parseClaimsJws(jwtToken) .getBody(); } } ``` 引用 3. 在您的Spring Boot应用程序中调用JwtUtils类来解析JWT: ```java String jwtToken = "your_jwt_token_here"; String secretKey = "your_secret_key_here"; Claims claims = JwtUtils.parseJwt(jwtToken, secretKey); ``` 通过这些步骤,您就可以在Spring Boot中使用jwt.io库来解析JWT了。请确保将"your_jwt_token_here"和"your_secret_key_here"替换为实际的JWT令牌和秘钥。引用<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Springboot + JWT-Token 生成与解析](https://blog.csdn.net/gaogzhen/article/details/113106736)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [springboot集成socket.io通过jwt-token身份认证鉴权](https://blog.csdn.net/qq_16334741/article/details/122949127)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值