我有一个ASP.Net C#应用程序需要每5分钟使用WebServices连接到一个外部API。
外部Web服务的要求如下:
我已经建立了所有以前的,但我目前有一个问题。存储当前和历史密码的最佳做法是什么?
显然,存储明文密码是一个糟糕的解决方案。我需要能够让我的web服务读取密码并随每个请求一起传输。我还需要能够访问所有历史密码,以确保我新生成的密码不重复。
理想情况下,我想将每个(加密的)密码存储在我的数据库中,并在需要调用webservice时解密它。我应该遵循最佳做法吗?我应该使用Microsoft.Practices.EnterpriseLibrary.Security.Cryptography.Cryptographer.EncryptSymmetric(..)加密每个密码吗?
注意:遗憾的是,我无权更改外部API的功能。我必须遵守规定。
答案 0 :(得分:6)
关于密码历史,我会选择两条路线之一:
答案 1 :(得分:1)
最简单的方法...使用ProtectedData类:
http://msdn.microsoft.com/en-us/library/system.security.cryptography.protecteddata.aspx
byte[] bytes = System.Text.Encoding.UTF8.GetBytes(password);
byte[] cypher = ProtectedData.Protect(data, null, DataProtectionScope.CurrentUser);
//... reverse
byte[] bytes = ProtectedData.Unprotect(cypher, null, DataProtectionScope.CurrentUser);
string password = System.Text.Encoding.UTF8.GetString(bytes);
答案 2 :(得分:0)
ASP.NET IIS注册工具(Aspnet_regiis.exe)可以加密和解密web.config的各个部分。应用程序中不需要特殊代码,因为ASP.NET 2.0将在运行时神奇地解密部分。