在网上找了一些关于xml序列化与反序列化的资料,摘录下: 
       在.NET下有一种技术叫做对象序列化,它可以将对象序列化为二进制文件、XML文件、SOAP文件,这样, 使用经过序列化的流进行传输效率就得到了大大的提升。  
       在.NET中提供了两种序列化:二进制序列化、XML和SOAP序列化。对于WEB应用来说,用得最多的是第二种———XML和SOAP序列化。  
       XML 序列化将对象的公共字段和属性或者方法的参数和返回值转换(序列化)为符合特定 XML 架构定义 语言 (XSD) 文档的 XML 流。  
       XML 序列化生成强类型的类,并为存储或传输目的将其公共属性和字段转换为序列格式(在此情况下为  
XML)。  
注意: 
1、XML 序列化不转换方法、索引器、私有字段或只读属性(只读集合除外)。 
2、使用Serialize和Deserialize需要指明命令空间System.Xml.Serialization,using System.IO。 
xml序列化简单的应用举例: 
有个类定义为: 
C#复制代码 
public class webinfo     
{     
    public string userName;     
    public string webName;     
    public string webUrl;     
}    
那么通过序列化我们可以将其序列化为: XML/HTML复制代码 
<?xml version="1.0"?>    
<webinfo xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">    
  <userName>脚本之家</userName>    
  <webName>脚本</webName>    
  <webUrl>https://www.jb51.net</webUrl>    
</webinfo>    
主要的代码如下: C#复制代码 
webinfo info = new webinfo();     
info.userName = "脚本之家";     
info.webName = "脚本";     
info.webUrl = "https://www.jb51.net";     
//用webinfo这个类造一个XmlSerializer     
XmlSerializer ser = new XmlSerializer(typeof(webinfo));     
//xml保存路径,序列化成功后可以通过查看该文件看到序列化后结果     
string path = Server.MapPath("webinfo.xml");     
try    
{     
    //Stream用于提供字节序列的一般视图,这里将在根目录下建立一个xml文件     
    Stream file = new FileStream(path, FileMode.Create, FileAccess.Write);     
    //把Stream对象和info一起传入,序列化出一个XML文件,如果没这一步,建立的xml内容为空     
    ser.Serialize(file, info);     
    //释放资源     
    file.Close();     
    file.Dispose();     
    Response.Write("序列化成功");     
}     
catch (Exception ex)     
{     
    Response.Write(ex.Message);     
}     
finally    
{     
}   
1
您可能感兴趣的文章:
