对象的序列化与反序列化,以xml,二进制流的方式,soap方式序列化对象

本文介绍如何使用.NET框架中的BinaryFormatter和SoapFormatter进行对象的序列化与反序列化,包括二进制和SOAP格式,并提供了具体的实现代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

System.Runtime.Serialization.Formatters.Soap 命名空间包含SoapFormatter 类,该类用于以SOAP 格式将对象序列化和反序列化。
生成使用此命名空间中的类型的应用程序时,必须引用System.Runtime.Serialization.Formatters.Soap.dll 程序集。

 

using System;
using System.Drawing;
using System.Collections;
using System.Windows.Forms;
using System.Data;
using System.Xml;
using System.IO;
using System.Text;
using System.Xml.Serialization;
using System.Runtime.Serialization.Formatters.Binary;
using System.Runtime.Serialization.Formatters.Soap;




namespace Serialization

    

    [Serializable]
    
public class Car
    
{
        
private string _Price;
        
private string _Owner;
        
private string m_filename;

        [XmlElement(ElementName 
= "Price")]
        
public string Price
        
{
            
get return this._Price; }
            
set this._Price = value; }
        }


        [XmlElement(ElementName 
= "Owner")]
        
public string Owner
        
{
            
get return this._Owner; }
            
set this._Owner = value; }
        }


        
public string Filename
        
{
            
get
            
{
                
return m_filename;
            }

            
set
            
{
                m_filename
=value;
            }

        }


        
public Car(string o, string p)
        
{
            
this.Price = p;
            
this.Owner = o;
        }



    }



    
public class  cxySerialize  
    
{   
        
/// <summary>
        
/// 序列化为对象
        
/// </summary>
        
/// <param name="objname"></param>
        
/// <param name="obj"></param>

        public static void BinarySerialize(string objname,object obj)
        
{
            
try
            
{
                
                
string filename=objname+".bin";
                
if(System.IO.File.Exists(filename))
                    System.IO.File.Delete(filename);
                FileStream fileStream 
= new FileStream(filename, FileMode.Create);
                
// 用二进制格式序列化
                BinaryFormatter binaryFormatter = new BinaryFormatter();
                binaryFormatter.Serialize(fileStream, obj);
                fileStream.Close(); 
            }

            
catch(Exception ex)
            
{
                MessageBox.Show(ex.Source);
            }

        }


        
/// <summary>
        
/// 从二进制文件中反序列化
        
/// </summary>
        
/// <param name="objname"></param>
        
/// <returns></returns>

        public static object BinaryDeserialize(string objname)
        
{
            System.Runtime.Serialization.IFormatter formatter 
= new BinaryFormatter();
            
//二进制格式反序列化
            string filename=objname+".bin";
            
if(!System.IO.File.Exists(filename))
                
throw new Exception("对反序列化之前,请先序列化");
            Stream stream 
= new FileStream(filename, FileMode.Open, FileAccess.Read, FileShare.Read);
            
object obj = formatter.Deserialize(stream);
            stream.Close();
            
return obj;
        }


        
/// <summary>
        
/// 序列化为soap 即xml
        
/// </summary>
        
/// <param name="objname"></param>
        
/// <returns></returns>

        public static void SoapSerialize(string objname,object obj)
        
{
            
try
            
{  
                
string filename=objname+".Soap";
                
if(System.IO.File.Exists(filename))
                    System.IO.File.Delete(filename);
                FileStream fileStream 
= new FileStream(filename, FileMode.Create);
                
// 序列化为Soap
                SoapFormatter formatter = new SoapFormatter();
                formatter.Serialize(fileStream, obj);
                fileStream.Close();

            }

            
catch(Exception ex)
            
{
                MessageBox.Show(ex.Source);
            }

        }



        
/// <summary>
        
/// 反序列号对象
        
/// </summary>
        
/// <param name="objname"></param>

        public static object SoapDeserialize(string objname)
        
{

            System.Runtime.Serialization.IFormatter formatter 
= new SoapFormatter();
            
string filename=objname+".Soap";
            
//Soap格式反序列化
            Stream stream = new FileStream(filename, FileMode.Open, FileAccess.Read, FileShare.Read);
            
object obj = formatter.Deserialize(stream);
            stream.Close();
            
return obj;
        }


        
public static void XmlSerialize(string objname,object obj)
        
{
             
            
try
            
{
                
string filename=objname+".xml";
                
if(System.IO.File.Exists(filename))
                    System.IO.File.Delete(filename);
                FileStream fileStream 
= new FileStream(filename, FileMode.Create);
                
// 序列化为xml
                SoapFormatter formatter = new SoapFormatter();
                formatter.Serialize(fileStream, obj);
                fileStream.Close(); 
            }

            
catch(Exception ex)
            
{
                MessageBox.Show(ex.Message);
            }


        }



        
/// <summary>
        
/// 从xml序列中反序列化
        
/// </summary>
        
/// <param name="objname"></param>
        
/// <returns></returns>

        public static object XmlDeserailize(string objname)
        

            System.Runtime.Serialization.IFormatter formatter 
= new SoapFormatter();
            
string filename=objname+".xml";
            
//Xml格式反序列化
            Stream stream = new FileStream(filename, FileMode.Open, FileAccess.Read, FileShare.Read);
            
object obj = formatter.Deserialize(stream);
            stream.Close();
            
return obj; 
        }


    
     
    }
   


}
 
二进制XML存储方案BinXML实现方法 BinXML是我个人杜撰出来的名字,不知道是否合适,也不知道是否已存在类似的解决方案。在vcer.net上我将前一段时间的这个BinXML方案贡献出来,希望能够广大vcer分享。 当时问题的背景是这样的,项目需要确定存储方案,这种方案需要满足如下要求: · 生成的单机板exe尽可能的不依赖于其它软件,如:数据库管理系统; · 存储的数据最好能够方便的拷贝,以满足项目的上报、汇总的功能; · 存储的格式以后可能还会变,变化不频繁,但是最好能支持这种变化; · 只需要数据的持久化反持久化的功能,不需要查询统计等复杂功能; · 存储的数据中可能包括一个或者多个的文件附件,如:word文档; · 存储的数据可能被不同的平台使用,如:windows或者linux; · 作为web项目的一部分,除了提供VC的接口之外,存储的数据格式需要提供java的接口; 我首先考虑到了MsAccess格式,文件型数据库,方便拷贝,而且表的设计很柔性化。在windows环境下,MsAccess似乎可以不需要再安装额外的驱动,但是在linux环境下,如何被java调用是个问题(当然,这个问题也是可以解决的,但是很别扭)。其次,使用RDB还有一个问题:数据的层次表达多值问题,将树型数据扁平化存储的方案是有的,但是,将几层简单的节点拆分成N个表格,岂不是杀鸡用牛刀? 其次的考虑当然是XML,然而XML是基于可读文本的,如何解决二进制数据问题?当然可以通过编码的途径来解决,但是这样使用XML是不是太牵强了?而且,XML有个缺陷,数据都是文本型的。要使用数值型、布尔型、日期型的数据,需要做进一步的解析。 那么就使用自定义的数据文件格式?传统情况下,我们会用一个或者若干个struct将数据打包,一下子塞进文件。但是现在用户说了:我们现在定义的数据结构可能会变:) 看来,我们的存储方案还必须要足够的柔性化。 想到最后,我决定还是借鉴XML的树型标签形式,来实现一种二进制的存储结构,即BinXML:) 关于src包 对于BinXML-src里面的例子,数据的结构类似于: BinXML-src.zip包括两部分,一部分是vc的工程,一部分是java的工程,在Visual C++6.0和eclipse+JDK1.4中都已编译、运行通过。大家可以运行BinXML-bin.zip里面的exe程序,测试一下BinXML文件的加载和保存功能。 对象模型 BinXML对象模型主要包括:文档(document)和节点(node)。每个文档包含一个根节点(root),根节点下面包含一个或者多个子节点,如此类推。 文档包含一个文件头,其中包含了一些标识串、操作系统版本、文件大小、文档创建时间等信息。 每个节点也包含一个节点头,表明该节点的名称以及大小。一般来说,用户不会直接接触到文件头和节点头这些信息。 如下为VC里的类声明: 在java里,定义了binxml.io包,其中的类、接口定义以上相似。 你很容易想到,使用BinXML,可以很方便地完成CTreeCtrl的持久化。 如何使用? 如下是VC中加载BinXML的代码片断: 对应的,写入BinXML的代码片断: 是不是很简单?在java里面,BinXML的一个测试用例: TODO 希望BinXML能给你带来一定的帮助和启发,更多的是希望能带来启发:)希望有兴趣的哥们继续完善BinXML,别忘了在你的大名之前保留我的版权信息: BinXML需要完善的地方表现在: · 暂时只实现了string/long/byte[],还没有提供其它类型的解析转换; · XML标签不支持属性,只支持子元素:) · 是不是可以提供一个oxm模型,完成BinXMLObject之间的直接映射,现在这个映射工作还是人工代码实现的,譬如:GetString/GetLong,等等。应该可以完善一个映射机制,自动根据定义好的类型进行转换;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值