zoukankan      html  css  js  c++  java
  • C#对MemoryStream压缩、加密

    对流进行压缩、加密的文章从网上看了不少,大多的例子是针对文件流的。近日因项目的要求,需要对内存流进行压缩、加密的操作。按照网上的例子,用内存流来代替文件流。结果还是花费了我很多的时间来调试,其间几乎放弃。最后终于调试通过了。这里做一些总结。

           在应用DeflateStream 或GZipStream进行压缩的时候,一定要先调用其实例的Close()方法,否则基流中的被压
    缩的数据是不完整的,无法进行解压缩操作。这一点很重要!
           对内存流进行加密后应用基流这前一定要调用 CryptoStream 的 FlushFinalBlock 方法,否则无法解密!

        public class Serialize
        {
            // 用于初始化对称密钥
            private static byte[] key = { 1234567890123456,
                
    7890123456789012
            };
            
    private static byte[] IV = { 1234567890123456 };


            
    /// <summary>
            
    /// 将对象压缩加密到字节数据
            
    /// </summary>
            
    /// <param name="obj">要压缩加密的对象</param>
            
    /// <returns>处理后生成的字节数组</returns>
            public static byte[] CompressEncryptToBytes(object obj)
            {
                
    // 建立对称密码信息
                MemoryStream ms = new MemoryStream();
                RijndaelManaged RM 
    = new RijndaelManaged();
                CryptoStream EnCrpStrm 
    = new CryptoStream(ms, RM.CreateEncryptor(key,IV), CryptoStreamMode.Write);
                DeflateStream zip 
    = new DeflateStream(EnCrpStrm, CompressionMode.Compress, true);
                
    try
                {
                    BinaryFormatter serializer 
    = new BinaryFormatter();
                    serializer.Serialize(zip, obj);
                    zip.Close();        
    // 在返回(return)这前一定要进行关闭
                    EnCrpStrm.FlushFinalBlock();    // 在返回(return)这前一定要进行调用。
                    return ms.ToArray();
                }
                
    catch (Exception e)
                {
                    MsgBoxs.Alert(e.ToString());
                    
    return null;
                }
                
    finally
                {
                    EnCrpStrm.Close();
                    ms.Close();
                }
            }

            
    /// <summary>
            
    /// 将字节数组进行解密解压还原成对象
            
    /// </summary>
            
    /// <param name="ary">要处理的字节数组</param>
            
    /// <returns>被还原的对象</returns>
            public static object DecompressDecryptToObject(byte[] ary)
            {
                MemoryStream ms 
    = new MemoryStream(ary);
                RijndaelManaged RM 
    = new RijndaelManaged();
                CryptoStream DeCrpStrm 
    = new CryptoStream(ms, RM.CreateDecryptor(key, IV), CryptoStreamMode.Read);
                DeflateStream UnZip 
    = new DeflateStream(DeCrpStrm, CompressionMode.Decompress);
                
    try
                {
                    BinaryFormatter serializer 
    = new BinaryFormatter();
                    
    return serializer.Deserialize(UnZip);
                }
                
    catch (Exception e)
                {
                    MsgBoxs.Alert(e.ToString());
                    
    return null;
                }
                
    finally
                {
                    UnZip.Close();
                    DeCrpStrm.Close();
                    ms.Close();
                }
            }

            
    /// <summary>
            
    /// 将对象压缩到字节数组
            
    /// </summary>
            
    /// <param name="obj">要压缩的对象</param>
            
    /// <returns>压缩后的字节数组</returns>
            public static byte[] CompressedToBytes(object obj)
            {
                MemoryStream ms 
    = new MemoryStream();
                DeflateStream zip 
    = new DeflateStream(ms, CompressionMode.Compress, true);
                
    try
                {
                    BinaryFormatter serializer 
    = new BinaryFormatter();
                    serializer.Serialize(zip, obj);
                    zip.Close();
                    
    byte[] ary = ms.ToArray();
                    ms.Close();
                    
    return ary;
                }
                
    catch (Exception e)
                {
                    zip.Close();
                    ms.Close();
                    MsgBoxs.Alert(e.ToString());
                    
    return null;
                }
            }

            /// <summary>
            /// 解压缩后对象
            /// </summary>
            /// <param name="ary">字节数组</param>
            /// <returns>对象</returns>
            public static object DecompressToObject(byte[] ary)
            {
                MemoryStream ms 
    = new MemoryStream(ary);
                DeflateStream UnZip 
    = new DeflateStream(ms, CompressionMode.Decompress);
                
    try
                {
                    BinaryFormatter serializer 
    = new BinaryFormatter();
                    
    object obj = serializer.Deserialize(UnZip);
                    UnZip.Close();
                    ms.Close();
                    
    return obj;
                }
                
    catch (Exception e)
                {
                    UnZip.Close();
                    ms.Close();
                    MsgBoxs.Alert(e.ToString());
                    
    return null;
                }
            }
        }
  • 相关阅读:
    【bzoj4399】魔法少女LJJ 并查集+权值线段树合并
    【bzoj4059】[Cerc2012]Non-boring sequences 分治
    【bzoj4390】[Usaco2015 dec]Max Flow LCA
    【bzoj4127】Abs 树链剖分+线段树
    【bzoj1222】[HNOI2001]产品加工 背包dp
    【bzoj4966】总统选举 随机化+线段树
    protected internal == internal
    框架的一点小随笔
    WPF 的 数据源属性 和 数据源
    Python 运算符重载
  • 原文地址:https://www.cnblogs.com/zpc870921/p/2638482.html
Copyright © 2011-2022 走看看