SpringSecurity02-oauth2登录源码分析
创始人
2025-05-31 03:41:48
0

基于用户名密码登录的demo实现oauth2授权码登录!

demo下载

配置解释

http.authorizeRequests()
        .mvcMatchers("/login").permitAll() //放行login请求
        .anyRequest().authenticated()//代表其他请求需要认证
        .and()
        .formLogin()//配置表单认证
        .loginPage("/login")//用来指定自定义登录界面,不使用SpringSecurity默认登录界面  注意:一旦自定义登录页面,必须指定登录url
        .loginProcessingUrl("/doLogin")//指定处理登录的请求url
        .and()
        .oauth2Login() // 开启oauth2登录
        .loginPage("/login") //不使用默认的oauth登录页面,否则无法密码登录
        .successHandler(oauth2AuthenticationSuccessHandler)
        .and()
        .csrf().disable(); //禁止csrf 跨站请求保护

源码分析

1. 访问根路径,重定向到登录页

在FilterChainProxy如下打断点:

浏览器访问:http://localhost:8035/

进入断点,观察过滤器:

可知多了两个Filter:

OAuth2AuthorizationRequestRedirectFilter :重定向过滤器,即当未认证时,重定向到登录页

OAuth2LoginAuthenticationFilter:授权登录过滤器,处理指定的授权登录

而且在UsernamePasswordAuthenticationFilter之前;

debug放行直到进入OAuth2AuthorizationRequestFilter:

因为当前请求根路径。并非授权登录请求,因此继续执行后续Filter;

debug放行进入OAuth2LoginAuthenticationFilter:

首先执行方法requiresAuthentication判断当前请求是否需要当前AuthenticationFilter执行认证:

可知OAuth2AuthenticationFilter处理的请求是/login/oauth2/code/,因此返回false:

不需要当前Filter执行认证,因此继续执行后续Filter:

 

直到现在,其实新加入的两个Filter都没有起作用,后续流程就是认证为匿名用户,授权校验抛出AccessDeniedExcepiton,然后ExceptionTranslateFilter处理重定向到登录页。

 

2. 点击gitee登录,页面重定向到gitee授权登录页面

提前打开https://gitee.com/,如果已登录,请先退出登录。

保持FilterChainProxy断点,点击gitee登录,请求 /oauth2/authorization/gitee

进入断点:

debug放行,直到进入OAuth2AuthorizationRequestRedirectFilter :

判断是否是授权登录请求,进入resolve方法:

进入resolveRegistrationId:

pattern是/oauth2/authorization/{registrationId},因此可解析出registrationId是gitee

继续执行getAction方法:

请求中没有action参数,返回默认的:login

debug下一步,进入resolve:

denbug下一步,发起重定向:

首先执行saveAuthorizationRequest方法,即保存本次请求相关的信息,以用于三方平台回调时可以再次获取,例如当回调时需要检查state参数是否一致,以保证安全;

进入sendRedirect方法:

debug放行,后续Filter不被执行,页面渲染授权登录页面(如果浏览器已登录过gitee将不会出现以下页面,而是直接进行回调,因为已登录啦):

3. gitee登录完成后回调完成认证,并响应信息

首次gitee授权登录时还需要确认授权,之后不会再出现该步骤;

保持FilterChainProxy断点,gitee登录和确认授权后,进入该断点:

 

当前请求是/login/oauth2/code/gitee,就是gitee回调请求,debug放行进入OAuth2LoginAuthenticationFilter:

同样先执行抽象父类AbstractAuthenticationProcessingFilter的判断是否需要执行认证的方法requiresAuthentication:

pattern是/login/oauth2/code/*,当前回调请求的url是/login/oauth2/code/gitee,因此匹配,开始执行认证:

进入OAuth2LoginAuthenticationFilter.attemptAuthentication方法:

可以看到回调请求中包含授权码code和state两个参数;

 

在removeAuthorizationRequest方法中根据state参数从会话中查询授权登录之前保存的请求对象(请求对象也有state参数),如果找不到则抛出异常:AUTHORIZATION_REQUEST_NOT_FOUND_ERROR_CODE

意思就是这次授权回调和当前会话无关,为了安全,有可能是黑客乱搞的链接被用户误点了,因此这里直接抛出异常;

继续执行:

构造认证请求,然后使用工厂模式执行认证,这个和用户名密码认证是一样的:

进入authenticate方法,并debug放行到下图断点:

可知处理OAuth2LoginAuthenticationToken的provider是OAuth2LoginAuthenticationProvider,进入:

debug放行:

 

这里会将OAuth2AuthenticationToken保存到SecurityContextHolder中,以使得SecurityContextPersistenceFilter能持久化到会话中,

可发现该认证结果包含了大量gitee用户信息,这和密码登录后认证为本地用户是不同的,本地用户可能有id等信息,gitee的id和本地用户的id不同;因此如果Controller中获取该Authentication对象后还需要做转换以匹配本地用户,这是不方便的,因此可以自定义认证成功后处理器中完成用户匹配:

handler中也使用了工厂模式,以支持不同授权登录方式对应不同的用户匹配方法;

debug放行,Controller返回当前认证信息:

4. 使用SavedRequestAwareAuthenticationSuccessHandler可实现回调原始请求

重启浏览器,访问localhost:8035/test,跳转登录页,使用gitee授权登录后,页面会重定向到localhost:8035/test

但是当前后端分离时,通过默认的SavedRequestAwareAuthenticationSuccessHandler就不能实现重定向到原始请求了。

 

相关内容

热门资讯

提振消费,如何增强供需适配性 云南大理白族自治州,游客(左)与摄影师一起挑选照片。 北京朝阳区,一名智能柜补货员在卸货。 以上图...
贝仕达克:预计2025年度净利... 每经AI快讯,贝仕达克1月30日晚间发布业绩预告,预计2025年归属于上市公司股东的净利润860万元...
英媒:随着就业市场降温,美国大... 来源:格隆汇APP 格隆汇1月30日|据英国金融时报,本周,美国的一些大型企业公布了裁员计划,预计将...
终结5连败!德约3-2逆转辛纳... 北京时间1月30日,2026赛季网球大满贯澳大利亚公开赛继续进行,在男单下半区的半决赛中,塞尔维亚天...
去年辽宁非金融企业债务融资达6... 1月30日,人民银行辽宁省分行召开2026年一季度新闻发布会,介绍2025年度辽宁省金融运行主要情况...
“大V带货”遭监管重拳:基金销... 记者 洪小棠 1月29日,证监会证券基金机构监管司发布了新一期《机构监管情况通报》(下称《通报》),...
ST宁科完成组织架构重大调整 ... 来源:新浪财经-鹰眼工作室 【财经网讯】宁夏中科生物科技股份有限公司(证券代码:600165,股票简...
原创 i... 很多人看到苹果这份“史上最强”季度成绩单时,第一反应都是:这销量也太夸张了吧? 尤其是大中华区 ...
Cloudflare入驻B站和... IT之家 1 月 30 日消息,Cloudflare 宣布入驻B站和小红书,认证显示为“Cloudf...
首日涨超160% 智能制造装备... 上证报中国证券网讯(记者 张雪)1月30日,美德乐正式登陆北交所。截至当日收盘,公司股价报109.5...
特朗普提名下一任美联储主席 据新华社消息,美国总统特朗普30日提名美联储前理事凯文·沃什为下任美联储主席,这一提名还需获得参议院...
由盈转亏、业绩下滑超85%!2... 面对每天上千份上市公司公告该看哪些?重大事项公告动辄几十页几百页重点是啥?公告里一堆专业术语不知道算...
原创 华... 金价的上涨和美元的下跌已经让整个依赖美西方货币体系和金融体系获利的人感受到了巨大的威胁。 在美国财政...
康佳集团原董事长周彬、原副总裁... 老牌家电巨头康佳集团(000016)在经历控制权变更与管理层换血的震荡期后,迎来了更为剧烈的“余震”...
安诚财险2025年揽收保费52... (图片来源:视觉中国) 蓝鲸新闻1月30日讯(记者 陈晓娟)日前,安诚财产保险股份有限公司(下称“安...
国际金价、银价,暴跌! 据新华社1月30日消息,国际黄金和白银价格1月29日上演“过山车”行情,双双站上高位后又暴跌,市场剧...
A股115家半导体公司2025... 近期,A股半导体行业上市公司陆续披露半年度业绩预告。据集微网统计,截至2026年1月30日,在已披露...
一图读懂服务消费新政:涉及交通... 红星资本局1月30日消息,为优化和扩大服务供给,聚焦重点领域、潜力领域,加快培育服务消费新增长点,促...
沪农商行:着力于稳健运营、控制... 证券日报网1月30日讯 ,沪农商行在接受调研者提问时表示,投资交易策略方面,公司将基于对2026年宏...
实力“圈粉”全球客:去年上海离... 记者从市税务局获悉,2025年境外旅客在沪办理退税申请单数量同比增长3倍,退税商品销售额和退税额均增...