*.DAT 從後綴名上也能理解其中的含義即:data文件,數據文件;這個文件有的可以用記事本工具打開,但是加密後就不一定了。
很多程序都創建dat文件來保存設定。創建一個只有自己才能解析得dat文件,並且可以讀取和寫入,寫一個類,它可以創建一個只有使用這個類才能解析得dat文件。同時讀取或寫入數據進dat文件時,也只可以使用這個類來讀取寫入。簡單來說就是這個類是打開讀取寫入這個dat文件得鑰匙!其實用來保存設置的文件後綴名可以各種各樣。
一、讀寫設置文件類
/// <summary>
/// 加密、解密
/// </summary>
public class EncryptUtilSeal
{
private static byte[] key = new byte[] { 78, 56, 61, 94, 12, 88, 56, 63, 66, 111, 102, 77, 1, 186, 97, 45 };
private static byte[] iv = new byte[] { 36, 34, 42, 122, 242, 87, 2, 90, 59, 117, 123, 63, 72, 171, 130, 61 };
private static IFormatter S_Formatter = null;
static EncryptUtilSeal()
{
S_Formatter = new BinaryFormatter();//創建一個序列化的對象
}
/// <summary>
/// 採用Rijndael128位加密二進制可序列化對象至文件
/// </summary>
/// <param name="para">二進制對象</param>
/// <param name="filePath">文件路徑</param>
/// <returns></returns>
public static bool EncryptObject(object para, string filePath)
{
//創建.bat文件 如果之前錯在.bat文件則覆蓋,無則創建
using (Stream fs = new FileStream(filePath, FileMode.Create, FileAccess.Write, FileShare.None))
{
RijndaelManaged RMCrypto = new RijndaelManaged();
CryptoStream csEncrypt = new CryptoStream(fs, RMCrypto.CreateEncryptor(key, iv), CryptoStreamMode.Write);
S_Formatter.Serialize(csEncrypt, para);//將數據序列化後給csEncrypt
csEncrypt.Close();
fs.Close();
return true;
}
}
/// <summary>
/// 從採用Rijndael128位加密的文件讀取二進制對象
/// </summary>
/// <param name="filePath">文件路徑</param>
/// <returns>二進制對象</returns>
public static object DecryptObject(string filePath)
{
//打開.bat文件
using (Stream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read))
{
object para;
RijndaelManaged RMCrypto = new RijndaelManaged();
CryptoStream csEncrypt = new CryptoStream(fs, RMCrypto.CreateDecryptor(key, iv), CryptoStreamMode.Read);
para = S_Formatter.Deserialize(csEncrypt); //將csEncrypt反序列化回原來的數據格式;
csEncrypt.Close();
fs.Close();
return para;
}
}
}
調用:
string ConfigFilePath = Path.Combine(System.AppDomain.CurrentDomain.BaseDirectory, "config.dat");
//寫入
Hashtable para = new Hashtable();
para.Add("ZH", tbxZH.Text);
para.Add("MM", pbxMM.Password);
EncryptUtilSeal.EncryptObject(para, ConfigFilePath);
//讀取
Hashtable para = new Hashtable();
object obj = EncryptUtilSeal.DecryptObject(ConfigFilePath);
para = obj as Hashtable;
string ZH = para["ZH"].ToString();
string MM = para["MM"].ToString();