加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c#通过DES加密算法加密大文件的方法

发布时间:2020-12-15 03:49:26 所属栏目:百科 来源:网络整理
导读:本篇章节讲解c#通过DES加密算法加密大文件的方法。供大家参考研究。具体实现方法如下: using System.Collections;using System.Configuration;using System.Data;using System.Linq;using System.Web;using System.Web.Security;using System.Web.U

本篇章节讲解c#通过DES加密算法加密大文件的方法。分享给大家供大家参考。具体实现方法如下:

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,100);
     encStream.Write(byteIn,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,des.CreateDecryptor(rgb,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,"<script>alert('失败成功!n');</script>");
   }
   File.Delete(filePathB);
  }
}

希望本文所述对大家的C#程序设计有所帮助。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读