【发布时间】:2010-10-18 22:57:57
【问题描述】:
与this 问题有点互补,但绝不相同。
如何创建受密码保护的文件?
【问题讨论】:
-
当您说“受密码保护的文件”时,您确实应该准确地说出您的意思。你的意思是当有人试图打开它时,会弹出一个“输入密码”对话框,还是什么?
-
是的,我就是这个意思
与this 问题有点互补,但绝不相同。
如何创建受密码保护的文件?
【问题讨论】:
加密:
private const int SaltSize = 8;
public static void Encrypt( FileInfo targetFile, string password )
{
var keyGenerator = new Rfc2898DeriveBytes( password, SaltSize );
var rijndael = Rijndael.Create();
// BlockSize, KeySize in bit --> divide by 8
rijndael.IV = keyGenerator.GetBytes( rijndael.BlockSize / 8 );
rijndael.Key = keyGenerator.GetBytes( rijndael.KeySize / 8 );
using( var fileStream = targetFile.Create() )
{
// write random salt
fileStream.Write( keyGenerator.Salt, 0, SaltSize );
using( var cryptoStream = new CryptoStream( fileStream, rijndael.CreateEncryptor(), CryptoStreamMode.Write ) )
{
// write data
}
}
}
并解密:
public static void Decrypt( FileInfo sourceFile, string password )
{
// read salt
var fileStream = sourceFile.OpenRead();
var salt = new byte[SaltSize];
fileStream.Read( salt, 0, SaltSize );
// initialize algorithm with salt
var keyGenerator = new Rfc2898DeriveBytes( password, salt );
var rijndael = Rijndael.Create();
rijndael.IV = keyGenerator.GetBytes( rijndael.BlockSize / 8 );
rijndael.Key = keyGenerator.GetBytes( rijndael.KeySize / 8 );
// decrypt
using( var cryptoStream = new CryptoStream( fileStream, rijndael.CreateDecryptor(), CryptoStreamMode.Read ) )
{
// read data
}
}
【讨论】:
System.Security.Cryptography.CryptographicException: Padding is invalid and cannot be removed.。这不是违背密码的目的吗? edit 不,这意味着您必须发现或暴力破解密码才能解密它,这正是密码的重点。德普。
使用 RijndaelManaged 类进行加密,使用 Rfc2898DeriveBytes 生成加密的密钥(和 IV)。
【讨论】: