如题,C#如何使用DES对zip文件加密?
压缩包zip文件中含有txt、excel、图片以及音视频文件;
密钥是固定的,如“2012-deszip”,请问各位大侠们,该如何实现呢?

解决方案 »

  1.   

    using System;
    using System.Collections;
    using System.Configuration;
    using System.Data;
    using System.Linq;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.HtmlControls;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Xml.Linq;
    using System.Text;
    using System.IO;
    using System.Security.Cryptography;public partial class Default2 : System.Web.UI.Page
    {
      protected void Page_Load(object sender, EventArgs e)
      {  }
      private static byte[] Keys = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };//自定义密匙
      private string filePathA;//储存文件路径
      private string filePathB;//储存文件复制后的路径
      /// <summary>
      /// 文件加密
      /// </summary>
      /// <param name="inFile">文件储存路径</param>
      /// <param name="outFile">储存文件复制的路径</param>
      /// <param name="encryptKey"></param>
      /// <returns></returns>
      public bool EncryptDES(string inFile, string outFile, string encryptKey)
      {
      byte[] rgb = Keys;
      try
      {
      byte[] rgbKeys = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
      FileStream inFs = new FileStream(inFile, FileMode.Open, FileAccess.Read);//读入流
      FileStream outFs = new FileStream(outFile, FileMode.OpenOrCreate, FileAccess.Write);// 等待写入流
      outFs.SetLength(0);//帮助读写的变量
      byte[] byteIn = new byte[100];//放临时读入的流
      long readLen = 0;//读入流的长度
      long totalLen = inFs.Length;//读入流的总长度
      int everylen=0;//每次读入流的长度
      DES des = new DESCryptoServiceProvider();//将inFile加密后放到outFile
      CryptoStream encStream = new CryptoStream(outFs, des.CreateEncryptor(rgb, rgbKeys), CryptoStreamMode.Write);
      while (readLen < totalLen)
      {
      everylen = inFs.Read(byteIn, 0, 100);
      encStream.Write(byteIn, 0, everylen);
      readLen = readLen + everylen;
      }
      encStream.Close();
      inFs.Close();
      outFs.Close();
      return true;//加密成功
      }
      catch (Exception ex)
      {
      Response.Write(ex.Message.ToString());
      return false;//加密失败
      }
      }
      public bool DecryptDES(string inFile, string outFile, string encryptKey)
      {
      byte[] rgb = Keys;
      try
      {
      byte[] rgbKeys = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
      FileStream inFs = new FileStream(inFile, FileMode.Open, FileAccess.Read);//读入流
      FileStream outFs = new FileStream(outFile, FileMode.OpenOrCreate, FileAccess.Write);// 等待写入流
      outFs.SetLength(0);//帮助读写的变量
      byte[] byteIn = new byte[100];//放临时读入的流
      long readLen = 0;//读入流的长度
      long totalLen = inFs.Length;//读入流的总长度
      int everylen=0;//每次读入流的长度
      DES des = new DESCryptoServiceProvider();//将inFile加密后放到outFile
      CryptoStream encStream = new CryptoStream(outFs, des.CreateDecryptor(rgb, rgbKeys), CryptoStreamMode.Write);
      while (readLen < totalLen)
      {
      everylen = inFs.Read(byteIn, 0, 100);
      encStream.Write(byteIn, 0, everylen);
      readLen = readLen + everylen;
      }
      encStream.Close();
      inFs.Close();
      outFs.Close();
      return true;//加密成功
      }
      catch (Exception ex)
      {
      Response.Write(ex.Message.ToString());
      return false;//加密失败
      }
      }
      /// <summary>
      /// 拷贝文件
      /// </summary>
      public void copyFile()
      {
      filePathA = this.fei.PostedFile.FileName;//获取文件全部路径
      string fileName = this.fei.FileName;
      string path = System.IO.Path.GetDirectoryName(filePathA);
      filePathB = path + "\\1" + fileName;//重新设置文件名
      File.Copy(filePathA, filePathB);
      }  protected void btnOK_Click(object sender, EventArgs e)
      {
      copyFile();
      if (EncryptDES(filePathB, filePathA, "mingrisoft"))
      {
      RegisterStartupScript("false", "<script>alert('加密成功!\\n');</script>");
      }
      else
      {
      RegisterStartupScript("false", "<script>alert('失败成功!\\n');</script>");
      }
      File.Delete(filePathB);
      }
      protected void btnCancel_Click(object sender, EventArgs e)
      {
      copyFile();
      if (DecryptDES(filePathB, filePathA, "mingrisoft"))
      {
      RegisterStartupScript("false", "<script>alert('加密成功!\\n');</script>");
      }
      else
      {
      RegisterStartupScript("false", "<script>alert('失败成功!\\n');</script>");
      }
      File.Delete(filePathB);
      }
    }
      

  2.   

    如果我的key值固定是“RMB-GOLD-2012-Phone”的话,上面的代码:
    private static byte[] Keys = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };//自定义密匙
    byte[] rgbKeys = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
    这两句需要改吗?谢谢!
      

  3.   

    看了DES加密原理还是有点没有搞懂,谁懂这块的帮忙看下啊,那两句需要改吗
      

  4.   

    来人回答一下啊,我用上面代码加密了,别人用java代码解密时还是不行啊
      

  5.   

    你用C#加密 用Java解密。。这个是不是有点囧
      

  6.   

    java中用的是Cipher这个类解密的,C#中用什么能和它对应呢,有木有人啊