微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在C#windows窗体应用程序中轻松加密密码?

如何轻松地从TextBox.Text中获取密码?

.NET框架中是否有一些内置的魔法?

解决方法

我们前一段时间讨论过关于密码的最佳实践,你可能会在那里找到一些好主意:

Salting Your Password: Best Practices?

我发现最简单的一个,虽然仍然相当安全,但是使用GUID作为你的盐.它是随机的,足够长.如果您包含GUID的字符串格式(‘{‘和’ – ‘字符),则效果最佳,但您不必这样做.

请记住,盐对于每个盐渍物品必须是唯一的,并且为了最安全,您应该使用加密安全随机生成器.还要记住,您必须将盐与密码一起存储,否则您将无法根据哈希版本检查纯文本版本!如果您愿意,可以存储未加密的盐;我通常将它放在与密码相同的表中的字段中.盐的目的不是保持隐藏,而是让彩虹表难以(希望不可能)及时计算.

这是一个可以在C#中使用的快速代码段:

RNGCryptoServiceProvider rng = new RNGCryptoServiceProvider();
byte[] buffer = new byte[1024];

rng.GetBytes(buffer);
string salt = BitConverter.ToString(buffer);
var saltedPassword = password + salt;

要么…

var salt = Guid.NewGuid().ToString();
var saltedPassword = password + salt;

原文地址:https://www.jb51.cc/csharp/101112.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐