我有一个IIS托管的WCF服务,它使用ProtectedData类来加密某些数据。很简单:
ProtectedData.Protect(data, null, DataProtectionScope.LocalMachine);和
ProtectedData.Unprotect(encryptedData, null, DataProtectionScope.LocalMachine);这一切在开发机器上都很好,但是当我在服务器上部署WCF服务(Windows 2008 R2)时,有些东西失败了。
System.Security.Cryptography.CryptographicException: The data is invalid.
at System.Security.Cryptography.ProtectedData.Unprotect(Byte[] encryptedData, Byte[] optionalEntropy, DataProtectionScope scope)问题是保护数据运行良好。没有错误,我有加密的数据,看起来没问题。但程序无法解密。我已经检查了所有可能出错的东西。我甚至尝试了一个小例子,在这个例子中,我对加密后的数据进行了解密(不涉及可能导致其他错误的其他操作或转换)。但还是失败了。我试着在网上找出解决方案。他们中的大多数人认为钥匙是无效的,并且有不适用于我的情况的解决方案。
有人能指点我找出哪里出了问题吗?
发布于 2022-06-13 11:45:22
对我来说,这个问题是由DB中一个旧的(而不是更新的)编码字符串引起的。我将DB中的编码字符串更新为新字符串。
只需创建一个临时变量:
var keyToProtectAndPutToDB = protector.Protect("MyUnProtectedKey123");并替换DB中keyToProtectAndPutToDB的现有值,并删除这个临时变量。
https://stackoverflow.com/questions/17446665
复制相似问题