【网络安全】重置密码token泄露,实现账户接管

未经许可,不得转载。

文章目录

正文

对某站点测试过程中,登录账户触发忘记密码功能点,其接口、请求及响应如下:

PUT /api/v1/people/forgot_password

img

可以看到,重置密码token和密码哈希均在响应中泄露。

删除cookie,查看响应包,发现服务器仍然返回重置密码token和密码哈希。

因此,此处存在未授权。

通过观察重置密码页面的url,发现其形式为:

https://www.redacted.com/reset_password?code="REPLACE_WITH_RESET_PASSWORD_CODE"&id=REPLACE_WITH_ID_PARAMETER

因此,我们能够接管任何一个受害者的账户。

img

原文出处:
https://infosecwriteups.com/account-take-over-through-reset-password-token-leaked-in-response-2500-reward-b643f97a7c67

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在使用 ASP.NET Core Identity 进行身份验证和授权时,可以使用 Token 实现密码重置功能。下面是一些大致的步骤: 1. 在 ASP.NET Core Identity 中配置 Token 服务,使得它可以发送重置密码邮件并生成 Token。 2. 当用户需要重置密码时,用户在重置密码页面中输入注册邮箱地址。 3. 应用程序发送重置密码邮件到注册邮箱地址,并在邮件中包含 Token。 4. 用户打开邮件并复制 Token。 5. 用户将 Token 粘贴到应用程序的密码重置页面中。 6. 应用程序验证 Token 是否正确并允许用户重置密码。 下面是一些代码片段,以便更好地理解如何实现这个过程: 1. 在 Startup.cs 文件的 ConfigureServices 方法中添加以下代码: ```csharp services.Configure<DataProtectionTokenProviderOptions>(options => options.TokenLifespan = TimeSpan.FromHours(3)); services.AddIdentity<ApplicationUser, IdentityRole>() .AddEntityFrameworkStores<ApplicationDbContext>() .AddDefaultTokenProviders() .AddTokenProvider<DataProtectorTokenProvider<ApplicationUser>>(TokenOptions.DefaultProvider); ``` 2. 在 PasswordReset 方法中,向用户发送重置密码邮件: ```csharp var user = await _userManager.FindByEmailAsync(email); if (user == null || !(await _userManager.IsEmailConfirmedAsync(user))) { // Don't reveal that the user does not exist or is not confirmed return RedirectToAction(nameof(ForgotPasswordConfirmation)); } // Send an email with this link var code = await _userManager.GeneratePasswordResetTokenAsync(user); var callbackUrl = Url.ResetPasswordCallbackLink(user.Id, code, Request.Scheme); await _emailSender.SendEmailAsync(email, "Reset Password", $"Please reset your password by clicking here: <a href='{callbackUrl}'>link</a>"); return RedirectToAction(nameof(ForgotPasswordConfirmation)); ``` 3. 在 ResetPassword 方法中,重置用户的密码: ```csharp var user = await _userManager.FindByEmailAsync(model.Email); if (user == null) { // Don't reveal that the user does not exist return RedirectToAction(nameof(ResetPasswordConfirmation)); } var result = await _userManager.ResetPasswordAsync(user, model.Code, model.Password); if (result.Succeeded) { return RedirectToAction(nameof(ResetPasswordConfirmation)); } foreach (var error in result.Errors) { ModelState.AddModelError(string.Empty, error.Description); } return View(); ``` 这些代码片段可以用作参考,以实现使用 Token 重置密码的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋说

感谢打赏,祝你平安喜乐。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值