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;
                }
            }
        }
  • 相关阅读:
    Atom+latex+中文环境
    pytorch中,不同的kernel对不同的feature map进行卷积之后输出某一个channel对应的多个feature map如何得到一个channel的feature map
    Ubuntu16.04上添加用户以及修改用户所属的组
    shell批处理文件,并将运算结果返回
    pytorch如何能够保证模型的可重复性
    Linux用管道命令对文件的移动
    python中调用多线程加速处理文件
    Python中random模块在主函数中设置随机种子是否对于调用的函数中的随机值产生影响?
    pytorch统计模型参数量
    pytorch使用tensorboardX进行网络可视化
  • 原文地址:https://www.cnblogs.com/zpc870921/p/2638482.html
Copyright © 2011-2022 走看看