前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >为什么加载了两个OAuth2AuthorizationRequestRedirectFilter分析

为什么加载了两个OAuth2AuthorizationRequestRedirectFilter分析

作者头像
阿提说说
发布2022-12-02 17:21:42
1990
发布2022-12-02 17:21:42
举报
文章被收录于专栏:Java技术进阶Java技术进阶

活动地址:CSDN21天学习挑战赛 相关文章:

  1. OAuth2的定义和运行流程
  2. Spring Security OAuth实现Gitee快捷登录
  3. Spring Security OAuth实现GitHub快捷登录
  4. Spring Security的过滤器链机制
  5. Spring Security OAuth Client配置加载源码分析
  6. Spring Security内置过滤器详解

前言

在前面的示例中,不知道你发现没有,打印出来的过滤器有重复的。

这是为什么?

带着问题,我们来分析一下源码。

源码分析

在以前的文章中,我们已经知道了过滤器会在AbstractConfiguredSecurityBuilder中的configure()中加载

我们进去打个断点看下,重启进入断点

看configurers有5个值,我们暂且不管这5个Configurer是干什么用的,后面再说,看左边的堆栈比较容易理解,认证管理器,原来是HttpSecurity在加载的时候,也会去调用doBuild(),这5个Configurer进行逐个调式后也并没有发现创建过滤器的地方,因此我们不再继续深入。

断点继续往下执行,终于看到了我们熟悉的几个过滤器

这么多过滤器你可以一个个去调式,但这也太费时间了,直接看OAuth2AuthorizationRequestRedirectFilter吧,创建一个对象总的用构造器吧,把这几个构造器全打上断点。

去掉前面的端点,直接进入了OAuth2AuthorizationRequestRedirectFilter的断点,这里就让我发现了秘密

原来在加载OAuth2LoginConfigurer的时候,也创建了一个OAuth2AuthorizationRequestRedirectFilter对象

🤔那在这里创建一个OAuth2AuthorizationRequestRedirectFilter干什么呢?留着这个问题吧。

还有一处创建OAuth2AuthorizationRequestRedirectFilter的地方是OAuth2ClientConfigurer

🤔这里创建的过滤器跟之前的有什么不同?

我真看不出来有什么不一样?

尽力了。

后面我用翻译的英语在stackoverflow上提了个问题🤣,看会不会理我。

目前这个问题在stackoverflow已经被关闭了,他们不想回答,这里面有一些跟外国人交流的问题。

提问要把代码以及配置写清楚,这样他们才能够调式,虽然我这里后来已经修改了,但还不是他们的菜,可能他们看不懂,或者觉得这个就不重要。

看看老外说的,However, why is it important? Do you have any problem with that?

所以再跟老外提问的时候,最好一开始就给想回答问题的人留一个好印象,让他们愿意继续回答。

后面在问了"码农小胖哥"后,表示用同一个OAuth2AuthorizationRequestRedirectFilter,是因为有部分逻辑是可以通用的,但其中又有不同的地方,通过set进一些自定义的逻辑,也有道理,可见我提的问题:

https://gitee.com/felord/21-days-oauth2/issues/I5M75H#note_12358310

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-08-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 源码分析
相关产品与服务
访问管理
访问管理(Cloud Access Management,CAM)可以帮助您安全、便捷地管理对腾讯云服务和资源的访问。您可以使用CAM创建子用户、用户组和角色,并通过策略控制其访问范围。CAM支持用户和角色SSO能力,您可以根据具体管理场景针对性设置企业内用户和腾讯云的互通能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档