【发布时间】:2015-08-31 03:46:43
【问题描述】:
我正在创建一个需要用户登录(用户名 + 密码)的应用程序。由于这是一个安全的应用程序,我使用 WPF 的 PasswordBox.SecurePassword 来安全地创建密码哈希(使用 SHA512CryptoServiceProvider,来自自定义流的哈希)以用作 Rfc2898DeriveBytes 的密码。假设我有一个 AES-256-CBC 实现,它可以安全地检索和存储密钥+IV,所以这不是问题。
我目前正在实施一种方法,让用户能够存储他们的密码,这样他们就不必每次登录时都输入密码。到目前为止,我能够使用 AES 自定义实现安全地存储密码,并且我可以安全地读取密码(也就是说,无需将密码以纯文本形式完全放入内存中)。
我遇到的问题是当我尝试替换 PasswordBox 中的文本时。 PasswordBox.SecurePassword 是只读的,我尝试使用 PasswordBox.SecurePassword.AppendChar(someChar) 但字段/值仍然为空。我想 PasswordBox.SecurePassword 只返回一个副本 (SecureString.Copy()) 而不是原始变量 (looking at .NET source code confirms this)。
有什么方法可以实现我想要的,或者我需要创建一个自定义 WPF 控件吗?
【问题讨论】:
-
“因为这是一个安全的应用程序” - 如果有人可以读取您应用程序的内存,那么该人也可以安装键盘记录器。
-
@CodeCaster 我们强制使用带有防键盘记录器的防病毒软件来尝试缓解这种情况。
标签: c# wpf security securestring