前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Spring Cloud Security配置JWT和OAuth2的集成实现授权管理(三)

Spring Cloud Security配置JWT和OAuth2的集成实现授权管理(三)

原创
作者头像
堕落飞鸟
发布2023-04-14 07:47:11
7520
发布2023-04-14 07:47:11
举报
文章被收录于专栏:飞鸟的专栏

编写JwtTokenFilter和JwtAuthenticationFilter

为了使用JWT和OAuth2进行授权管理,我们需要编写两个过滤器:JwtTokenFilter和JwtAuthenticationFilter。

JwtTokenFilter用于提取和验证JWT令牌:

代码语言:javascript
复制
public class JwtTokenFilter implements GatewayFilter {

    private final ReactiveJwtDecoder jwtDecoder;

    public JwtTokenFilter(ReactiveJwtDecoder jwtDecoder) {
        this.jwtDecoder = jwtDecoder;
    }

    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        String authorizationHeader = exchange.getRequest().getHeaders().getFirst(HttpHeaders.AUTHORIZATION);
        if (authorizationHeader != null && authorizationHeader.startsWith("Bearer ")) {
            String token = authorizationHeader.substring(7);
            return jwtDecoder.decode(token)
                    .flatMap(jwt -> {
                        exchange.getRequest().mutate()
                                .header("X-User-Id", jwt.getSubject())
                                .header("X-User-Roles", jwt.getClaimAsStringList("roles"))
                                .build();
                        return chain.filter(exchange);
                    })
                    .onErrorResume(e -> chain.filter(exchange));
        }
        return chain.filter(exchange);
    }

}

在上面的代码中,我们使用ReactiveJwtDecoder接口来解码JWT令牌,并使用filter方法来提取和验证JWT令牌。如果JWT令牌有效,则将用户ID和角色添加到请求标头中。否则,我们将继续处理请求。

JwtAuthenticationFilter用于验证OAuth2授权并将OAuth2令牌添加到请求标头中:

代码语言:javascript
复制
public class JwtAuthenticationFilter extends AbstractGatewayFilterFactory<JwtAuthenticationFilter.Config> {

    private final ReactiveOAuth2AuthorizedClientService authorizedClientService;

    public JwtAuthenticationFilter(ReactiveOAuth2AuthorizedClientService authorizedClientService) {
        super(Config.class);
        this.authorizedClientService = authorizedClientService;
    }

    @Override
    public GatewayFilter apply(Config config) {
        return (exchange, chain) -> {
            return exchange.getPrincipal()
                    .cast(OAuth2AuthenticationToken.class)
                    .flatMap(authentication -> authorizedClientService.loadAuthorizedClient(
                            authentication.getAuthorizedClientRegistrationId(),
                            authentication.getName())
                            .flatMap(authorizedClient -> {
                                exchange.getRequest().mutate()
                                        .header(HttpHeaders.AUTHORIZATION,
                                                "Bearer " + authorizedClient.getAccessToken().getTokenValue())
                                        .build();
                                return chain.filter(exchange);
                            })
                            .switchIfEmpty(chain.filter(exchange)));
        };
    }

    public static class Config {}

}

在上面的代码中,我们使用ReactiveOAuth2AuthorizedClientService接口来获取已授权的OAuth2客户端,并使用filter方法将OAuth2令牌添加到请求标头中。如果找不到已授权的客户端,则继续处理请求。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 编写JwtTokenFilter和JwtAuthenticationFilter
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档