土木堡之战

作者:小菜 更新时间:2024-06-09 点击数:
简介:百探网提供最新最全的美食,汽车,数码,宠物,婚嫁,生活,游戏,育儿,养生,热点的内容

【菜科解读】

大家都爱看

花生五大新本事你知道吗?

花生五大新本事你知道吗? 1都溪林场空中怪车事件真相 会是外星人所为吗10热度 2第二次世界大战发生的10件未解的神秘事件10热度 3通古斯大爆炸事件真相 猜测是神秘力量还是外星人造成10热度 4乐山大佛闭眼事件真相 佛祖真的显灵了10热度 5恐龙还在吗?最新恐龙目击事件真相 10热度

今日头条

天启大爆炸事件真相

天启大爆炸事件真相

古埃及木乃伊复活事件真相

古埃及木乃伊复活事件真相

秦始皇陵灵异事件真相

秦始皇陵灵异事件真相

盘点16个清陵被盗事件真相

盘点16个清陵被盗事件真相

猜你喜欢

花生五大新本事你知道吗?

花生五大新本事你知道吗?

西梅宝宝能吃吗?

西梅宝宝能吃吗?

故宫有哪些御猫?发现北京不一样的美

故宫有哪些御猫?发现北京不一样的美

埃博拉病毒僵尸怎么回事?发病像僵尸撕咬人类和动物

埃博拉病毒僵尸怎么回事?发病像僵尸撕咬人类和动物

武汉十大鬼楼排行榜 千万不要一个人去毛骨悚然

武汉十大鬼楼排行榜 千万不要一个人去毛骨悚然

热门推荐

刘邦:从布衣到帝王的惊世骇浪

刘邦:从布衣到帝王的惊世骇浪

TVB力捧六大艺人,将打造新一代奥运六星,网友直呼全都不认识

TVB力捧六大艺人,将打造新一代奥运六星,网友直呼全都不认识

1986年华航事件纪念封

1986年华航事件纪念封

让刘邦在白登吃大亏,不得不和亲的根源,不是匈奴而是另有其人?

让刘邦在白登吃大亏,不得不和亲的根源,不是匈奴而是另有其人?

C#开发给文件加密解密实现代码分享

西西在网上搜索相关文件加密的程序,发现给出的基本都是针对“字符创”、“文本”的加密与解密。

对视频文件、图片等一般文件的加密解密程序少之又少,故写下此文,实现一个对一般文件进行加密的小工具。

程序的主要功能是:用户通过文件选择框选择要加密的文件-》输入密码进行加密;选择加密后的文件,输入密码进行解密。

程序的主界面如下: 三个按钮的Click事件处理程序如下: private void btnSelectFile_Click(object sender, EventArgs e) { if (openFileDialog1.ShowDialog() == System.Windows.Forms.DialogResult.OK) { txtFileName.Text = openFileDialog1.FileName ; } } private void btnEncryptFile_Click(object sender, EventArgs e) { string inFile=txtFileName.Text; string outFile = inFile + ".dat"; string password=txtPassword.Text ; DESFile.DESFileClass.EncryptFile(inFile, outFile, password);//加密文件 //删除加密前的文件 File.Delete(inFile); txtFileName.Text = string.Empty; MessageBox.Show("加密成功"); } private void btnDecryptFile_Click(object sender, EventArgs e) { string inFile = txtFileName.Text; string outFile = inFile.Substring(0,inFile.Length - 4); string password = txtPassword.Text; DESFile.DESFileClass.DecryptFile (inFile, outFile, password);//解密文件 //删除解密前的文件 File.Delete(inFile); txtFileName.Text = string.Empty; MessageBox.Show("解密成功"); } 加密解密的Help文件源码如下:using System;using System.Collections.Generic;using System.Text;using System.Security.Cryptography;using System.IO;namespace DESFile{ /// /// 异常处理类 /// public class CryptoHelpException : ApplicationException { public CryptoHelpException(string msg) : base(msg) { } } /// /// CryptHelp /// public class DESFileClass { private const ulong FC_TAG = 0xFC010203040506CF; private const int BUFFER_SIZE = 128 * 1024; /// /// 检验两个Byte数组是否相同 /// /// Byte数组 /// Byte数组 /// true-相等 private static bool CheckByteArrays(byte[] b1, byte[] b2) { if (b1.Length == b2.Length) { for (int i = 0; i /// 创建DebugLZQ ,http://www.cnblogs.com/DebugLZQ /// /// 密码 /// /// 加密对象 private static SymmetricAlgorithm CreateRijndael(string password, byte[] salt) { PasswordDeriveBytes pdb = new PasswordDeriveBytes(password, salt, "SHA256", 1000); SymmetricAlgorithm sma = Rijndael.Create(); sma.KeySize = 256; sma.Key = pdb.GetBytes(32); sma.Padding = PaddingMode.PKCS7; return sma; } /// /// 加密文件随机数生成 /// private static RandomNumberGenerator rand = new RNGCryptoServiceProvider(); /// /// 生成指定长度的随机Byte数组 /// /// Byte数组长度 /// 随机Byte数组 private static byte[] GenerateRandomBytes(int count) { byte[] bytes = new byte[count]; rand.GetBytes(bytes); return bytes; } /// /// 加密文件 /// /// 待加密文件 /// 加密后输入文件 /// 加密密码 public static void EncryptFile(string inFile, string outFile, string password) { using (FileStream fin = File.OpenRead(inFile), fout = File.OpenWrite(outFile)) { long lSize = fin.Length; // 输入文件长度 int size = (int)lSize; byte[] bytes = new byte[BUFFER_SIZE]; // 缓存 int read = -1; // 输入文件读取数量 int value = 0; // 获取IV和salt byte[] IV = GenerateRandomBytes(16); byte[] salt = GenerateRandomBytes(16); // 创建加密对象 SymmetricAlgorithm sma = DESFileClass.CreateRijndael(password, salt); sma.IV = IV; // 在输出文件开始部分写入IV和salt fout.Write(IV, 0, IV.Length); fout.Write(salt, 0, salt.Length); // 创建散列加密 HashAlgorithm hasher = SHA256.Create(); using (CryptoStream cout = new CryptoStream(fout, sma.CreateEncryptor(), CryptoStreamMode.Write), chash = new CryptoStream(Stream.Null, hasher, CryptoStreamMode.Write)) { BinaryWriter bw = new BinaryWriter(cout); bw.Write(lSize); bw.Write(FC_TAG); // 读写字节块到加密流缓冲区 while ((read = fin.Read(bytes, 0, bytes.Length)) != 0) { cout.Write(bytes, 0, read); chash.Write(bytes, 0, read); value += read; } // 关闭加密流 chash.Flush(); chash.Close(); // 读取散列 byte[] hash = hasher.Hash; // 输入文件写入散列 cout.Write(hash, 0, hash.Length); // 关闭文件流 cout.Flush(); cout.Close(); } } } /// /// 解密文件 /// /// 待解密文件 /// 解密后输出文件 /// 解密密码 public static void DecryptFile(string inFile, string outFile, string password) { // 创建打开文件流 using (FileStream fin = File.OpenRead(inFile), fout = File.OpenWrite(outFile)) { int size = (int)fin.Length; byte[] bytes = new byte[BUFFER_SIZE]; int read = -1; int value = 0; int outValue = 0; byte[] IV = new byte[16]; fin.Read(IV, 0, 16); byte[] salt = new byte[16]; fin.Read(salt, 0, 16); SymmetricAlgorithm sma = DESFileClass.CreateRijndael(password, salt); sma.IV = IV; value = 32; long lSize = -1; // 创建散列对象, 校验文件 HashAlgorithm hasher = SHA256.Create(); using (CryptoStream cin = new CryptoStream(fin, sma.CreateDecryptor(), CryptoStreamMode.Read), chash = new CryptoStream(Stream.Null, hasher, CryptoStreamMode.Write)) { // 读取文件长度 BinaryReader br = new BinaryReader(cin); lSize = br.ReadInt64(); ulong tag = br.ReadUInt64(); if (FC_TAG != tag) throw new CryptoHelpException("文件被破坏"); long numReads = lSize / BUFFER_SIZE; long slack = (long)lSize % BUFFER_SIZE; for (int i = 0; i 0) { read = cin.Read(bytes, 0, (int)slack); fout.Write(bytes, 0, read); chash.Write(bytes, 0, read); value += read; outValue += read; } chash.Flush(); chash.Close(); fout.Flush(); fout.Close(); byte[] curHash = hasher.Hash; // 获取比较和旧的散列对象 byte[] oldHash = new byte[hasher.HashSize / 8]; read = cin.Read(oldHash, 0, oldHash.Length); if ((oldHash.Length != read) || (!CheckByteArrays(oldHash, curHash))) throw new CryptoHelpException("文件被破坏"); } if (outValue != lSize) throw new CryptoHelpException("文件大小不匹配"); } } }} 开,发给,文件,加密解密,实现,代码,分享,西西,

C#编程实现加密解密文件夹核心代码

用C#语言实现一个文件夹锁的程序,网上类似的“xxx文件夹xxx”软件很多,但是基本上都是C/C++语言实现的,且都没有提供源码(这个可以理解,毕竟是加密程序,不应该泄露源码)。

程序的基本原理是:用C#语言重命名文件夹,通过重命名使之成为windows安全文件的类标识符。

具体的方法是为文件夹添加拓展名“.{2559a1f2-21d7-11d4-bdaf-00c04f60b9f0}”(.{2559a1f2-21d7-11d4-bdaf-00c04f60b9f0}是windows安全文件的类标识符),这时文件夹的图标就会变成一把锁,这样文件夹就被加锁了。

程序的主界面非常简洁,截图如下:程序中加密解密文件夹的核心代码如下: private void btnBrowseFolder_Click(object sender, EventArgs e) { status = lockType;// if (folderBrowserDialog1.ShowDialog() == DialogResult.OK) { DirectoryInfo d = new DirectoryInfo(folderBrowserDialog1.SelectedPath); string selectedpath = d.Parent.FullName + d.Name; if (folderBrowserDialog1.SelectedPath.LastIndexOf(".{") == -1)//通过文件夹名称,判断加密 { SetPwd(folderBrowserDialog1.SelectedPath); if (!d.Root.Equals(d.Parent.FullName)) { d.MoveTo(d.Parent.FullName + "\\" + d.Name + status);//文件夹重命名 } else d.MoveTo(d.Parent.FullName + d.Name + status); txtFolderPath.Text = folderBrowserDialog1.SelectedPath; } else//解密文件夹 { status = GetStatus(status); bool s = CheckPwd(); if (s) { File.Delete(folderBrowserDialog1.SelectedPath + "\\key.xml"); string path = folderBrowserDialog1.SelectedPath.Substring(0, folderBrowserDialog1.SelectedPath.LastIndexOf(".")); d.MoveTo(path); txtFolderPath.Text = path; } } } }程序的运行效果如下:以加密D盘下面的test文件夹为例,结果如下:首先通过folderBrowserDialog选择相应的文件夹输入密码,加锁效果如下:此时双击文件夹已经无法打开。

选择加密后的test文件夹,输入加密时输入的密码,可解锁。

test文件夹已经解密结束语:本文件夹加密程序是通过重命名文件夹的方式实现的,加密强度较弱,牛人绕道,写出来给大家多个谈资~ 编程,实现,加密解密,文件夹,核心,代码,用,

加入收藏
               

土木堡之战

点击下载文档

格式为doc格式

  • 账号登录
社交账号登录