C#創建及讀取DAT文件

 *.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();

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章