ASP.NET Identity 中的用户密码PasswordHash 如何自定义加密或者明文存储?

boyyao 2020-06-09 05:30:02
因为有现有程序需要访问同一个字段。现有程序又不方便更改。所以希望能自定义加密方式。请问如何实现?
...全文
1051 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
masanaka 2020-06-09
  • 打赏
  • 举报
回复
实现IPasswordHasher这个接口,只要实装HashPassword和VerifyHashedPassword这两个方法,在HashPassword里用你自己想用的hash规则。
然后在Startup的ConfigureServices里注册你的实现,记得要在设定Identity之前,是AddDefaultIdentity还是AddIdentity,这个取决你。
最简单的例子,比方说hash规则就是原密码+'abc’。
public class MyPasswordHasher<TUser> : IPasswordHasher<TUser> where TUser : class
{
public string HashPassword(TUser user, string password)
{
return $"{password}abc";
}

public PasswordVerificationResult VerifyHashedPassword(TUser user, string hashedPassword, string providedPassword)
{
if (HashPassword(user, providedPassword).Equals(hashedPassword))
{
return PasswordVerificationResult.Success;
}
else
{
return PasswordVerificationResult.Failed;
}
}
}

然后在ConfigureServices里注册
public void ConfigureServices(IServiceCollection services)
{
services.AddScoped<IPasswordHasher<IdentityUser>, MyPasswordHasher<IdentityUser>>();

services.AddDbContext<ApplicationDbContext>(options =>
options.UseSqlServer(
Configuration.GetConnectionString("DefaultConnection")));
services.AddDefaultIdentity<IdentityUser>(options => options.SignIn.RequireConfirmedAccount = true)
.AddEntityFrameworkStores<ApplicationDbContext>();
services.AddControllersWithViews();
services.AddRazorPages();
}

注册密码是Cph-111,注册完后你就可以在数据库里看到按照自定义hash规则生成的PasswordHash。
  • 打赏
  • 举报
回复
收购微软,逼微软把你的功能改到 ASP.NET 新版本中。
github_36000833 2020-06-09
  • 打赏
  • 举报
回复
明文存储?

教训还不够深刻??
极客诗人 2020-06-09
  • 打赏
  • 举报
回复
identity的方法重写?

62,247

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧