如何在c#中加密和解密pdf文件?

时间:2015-05-27 06:03:24

标签: c# visual-studio-2010

是否可以在c#中加密pdf文件并在其上再次解密?我已经在sql数据库中加密了一条记录,但我需要在pdf文件上进行。我怎么能这样做?

1 个答案:

答案 0 :(得分:0)

我在项目中上传和下载文件时使用的这段代码,您可以使用它

喜欢

var myFile = your file;
   if (System.IO.File.Exists (myFile.Path)) {
          var decreypt = new FileEncryptDecrypt ();

          decreypt.DecryptFile (myFile.Path/*input file*/, tempFilePath/*output*/);
        } 

    using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Security.Cryptography;
using System.Text;
using System.Threading.Tasks;

namespace Website.Server
{


    public class FileEncryptDecrypt
    {
      //  private const string password = @"myKey123"; // Your Key Here

        /// <summary>
        /// Encrypts a file using AES 
        /// </summary>
        /// <param name="inputFile">inputFile Path</param>
        /// <param name="outputFile">outputFile path</param>
        public  void EncryptFile(string inputFile, string outputFile)
        {

            try
            {
                UnicodeEncoding UE = new UnicodeEncoding();
                byte[] key = UE.GetBytes(Settings.ServerSettings.EncDecKey);

                string cryptFile = outputFile;
                FileStream fsCrypt = new FileStream(cryptFile, FileMode.Create);

                //  RijndaelManaged RMCrypto = new RijndaelManaged();
                var RMCrypto = Aes.Create();
                CryptoStream cs = new CryptoStream(fsCrypt,
                    RMCrypto.CreateEncryptor(key, key),
                    CryptoStreamMode.Write);

                FileStream fsIn = new FileStream(inputFile, FileMode.Open);

                int data;
                while ((data = fsIn.ReadByte()) != -1)
                    cs.WriteByte((byte)data);


                fsIn.Dispose();
                cs.Dispose();
                fsCrypt.Dispose();
            }
            catch(Exception ex)
            {
              var msg=ex.Message   ;  /// MessageBox.Show("Encryption failed!", "Error");
            }
        }

        /// <summary>
        /// Decrypts a file using Aes .
        /// </summary>
        /// <param name="inputFile">inputFile Path</param>
        /// <param name="outputFile">outputFile path</param>
        public  void DecryptFile(string inputFile, string outputFile)
        {
            try
            {

                UnicodeEncoding UE = new UnicodeEncoding();
                byte[] key = UE.GetBytes(Settings.ServerSettings.EncDecKey);

                FileStream fsCrypt = new FileStream(inputFile, FileMode.Open);

                var RMCrypto = Aes.Create();
                // RijndaelManaged RMCrypto = new RijndaelManaged();

                CryptoStream cs = new CryptoStream(fsCrypt,
                    RMCrypto.CreateDecryptor(key, key),
                    CryptoStreamMode.Read);

                FileStream fsOut = new FileStream(outputFile, FileMode.Create);

                int data;
                while ((data = cs.ReadByte()) != -1)
                    fsOut.WriteByte((byte)data);

                fsOut.Dispose();
                cs.Dispose();
                fsCrypt.Dispose();

            }
            catch(Exception ex)
            {
               var msg=ex .Message  ;
            }
        }

        private static void EncryptData(String inName, String outName, byte[] rijnKey, byte[] rijnIV)
        {
            //Create the file streams to handle the input and output files.
            FileStream fin = new FileStream(inName, FileMode.Open, FileAccess.Read);
            FileStream fout = new FileStream(outName, FileMode.OpenOrCreate, FileAccess.Write);
            fout.SetLength(0);

            //Create variables to help with read and write.
            byte[] bin = new byte[100]; //This is intermediate storage for the encryption.
            long rdlen = 0;              //This is the total number of bytes written.
            long totlen = fin.Length;    //This is the total length of the input file.
            int len;                     //This is the number of bytes to be written at a time.

            var rijn = System.Security.Cryptography.Aes.Create();

            //   SymmetricAlgorithm rijn = new SymmetricAlgorithm .Create(); //Creates the default implementation, which is RijndaelManaged.         
            CryptoStream encStream = new CryptoStream(fout, rijn.CreateEncryptor(rijnKey, rijnIV), CryptoStreamMode.Write);

            Console.WriteLine("Encrypting...");

            //Read from the input file, then encrypt and write to the output file.
            while (rdlen < totlen)
            {
                len = fin.Read(bin, 0, 100);
                encStream.Write(bin, 0, len);
                rdlen = rdlen + len;
                Console.WriteLine("{0} bytes processed", rdlen);
            }

            encStream.Dispose();
            fout.Dispose();
            fin.Dispose();
        }
    }
}