ASP.NET - 加密文件
创始人
2024-11-11 20:01:07
0

在ASP.NET中加密文件有多种方式,以下是一种解决方法的代码示例:

using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;

public class FileEncryption
{
    public static void EncryptFile(string inputFile, string outputFile, string password)
    {
        byte[] salt = GenerateSalt();
        byte[] passwordBytes = Encoding.UTF8.GetBytes(password);

        using (FileStream fsInput = new FileStream(inputFile, FileMode.Open))
        using (FileStream fsOutput = new FileStream(outputFile, FileMode.Create))
        {
            using (RijndaelManaged aes = new RijndaelManaged())
            {
                aes.KeySize = 256;
                aes.BlockSize = 128;
                aes.Padding = PaddingMode.PKCS7;

                byte[] key = new Rfc2898DeriveBytes(passwordBytes, salt, 1000).GetBytes(aes.KeySize / 8);
                aes.Key = key;
                aes.IV = new Rfc2898DeriveBytes(passwordBytes, salt).GetBytes(aes.BlockSize / 8);

                fsOutput.Write(salt, 0, salt.Length);

                using (CryptoStream cs = new CryptoStream(fsOutput, aes.CreateEncryptor(), CryptoStreamMode.Write))
                {
                    byte[] buffer = new byte[4096];
                    int bytesRead;

                    while ((bytesRead = fsInput.Read(buffer, 0, buffer.Length)) > 0)
                    {
                        cs.Write(buffer, 0, bytesRead);
                    }
                }
            }
        }
    }

    public static void DecryptFile(string inputFile, string outputFile, string password)
    {
        byte[] passwordBytes = Encoding.UTF8.GetBytes(password);
        byte[] salt = new byte[32];

        using (FileStream fsInput = new FileStream(inputFile, FileMode.Open))
        using (FileStream fsOutput = new FileStream(outputFile, FileMode.Create))
        {
            fsInput.Read(salt, 0, salt.Length);

            using (RijndaelManaged aes = new RijndaelManaged())
            {
                aes.KeySize = 256;
                aes.BlockSize = 128;
                aes.Padding = PaddingMode.PKCS7;

                byte[] key = new Rfc2898DeriveBytes(passwordBytes, salt, 1000).GetBytes(aes.KeySize / 8);
                aes.Key = key;
                aes.IV = new Rfc2898DeriveBytes(passwordBytes, salt).GetBytes(aes.BlockSize / 8);

                using (CryptoStream cs = new CryptoStream(fsOutput, aes.CreateDecryptor(), CryptoStreamMode.Write))
                {
                    byte[] buffer = new byte[4096];
                    int bytesRead;

                    while ((bytesRead = fsInput.Read(buffer, 0, buffer.Length)) > 0)
                    {
                        cs.Write(buffer, 0, bytesRead);
                    }
                }
            }
        }
    }

    private static byte[] GenerateSalt()
    {
        byte[] salt = new byte[32];

        using (RNGCryptoServiceProvider rngCsp = new RNGCryptoServiceProvider())
        {
            rngCsp.GetBytes(salt);
        }

        return salt;
    }
}

使用示例:

string inputFile = "path/to/input/file";
string encryptedFile = "path/to/encrypted/file";
string decryptedFile = "path/to/decrypted/file";
string password = "your-password";

FileEncryption.EncryptFile(inputFile, encryptedFile, password);
FileEncryption.DecryptFile(encryptedFile, decryptedFile, password);

请注意,此示例使用Rijndael算法进行文件加密和解密,并采用PBKDF2(基于RFC 2898)来生成密钥和初始化向量。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...