博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
WCF序列化
阅读量:6266 次
发布时间:2019-06-22

本文共 3236 字,大约阅读时间需要 10 分钟。

在WCF中,提供了专门用来序列化和反序列操作的类,该类就是DataContractSerializer类。一般而言,WCF会自动选择使用DataContractSerializer来对可序列话数据契约进行序列化,不需要开发者直接调用。WCF除了支持DataContractSerializer类来进行序列化外,还支持另外两种序列化器,这两种序列化器分别为:XMLSerializer(定义在System.XML.Serialization namespace)和NetDataContractSerializer (定义在System.XML.Serialization namespace)。XmlSerializer类不是WCF专用的类,Asp.net Web服务统一使用该类作为序列化器,但XmlSerializer类支持的类少于DataContractSerializer列支持的类型,但它允许对生成的XML进行更多的控制,并且支持更多的XML架构定义语言(XSD)标准。它不需要在可序列化类上有任何声明性的属性。

DataContractSerializer类与NetDataContractSerializer类类似,它们之间主要的区别在于:在使用NetDataContractSerializer进行序列化时,不需要指定序列化的类型,如:

1
2
3
4
5
6
7
8
aNetDataContractSerializer serializer =
    
new 
NetDataContractSerializer(); 
// 不需要明确指定序列化的类型
serializer.WriteObject(writer, p);
 
// 而使用DataContractSerializer需要明确指定序列化的类型
DataContractSerializer serializer =
            
new 
DataContractSerializer(
typeof
(Order));
// 需要明确指定序列化的类型
        
serializer.WriteObject(writer, p);

使用DataContractSerializer类生成的XML文件与原始对象之间的映射关系如下(默认情况):

1. Root Element为对象的Type Name——DataContractOrder

2. Type的Namespace会被加到XML根节点的Namespace中

3. 对象的所有成员以XML Element的形式而不是以XML Attribute的形式输出。

4. 所以对象在XML的输出顺序是按照字母排序。

5. 所有成员的Elelement 名称为成员名称。

6. 不论成员设置怎样的作用域(public,protected,internal,甚至市Private),

所有运用了DataMemberAttribute的成员均被序列化到XML中,

7. Type和成员必须运用DataContractAttribute和DataMemberAttribute才能被序列化。

可以通过这两个Attribute(DataContractAttribute和DataMemberAttribute)制定相关的参数来生成所需的XML 结构

1. Root Element可以通过DataContractAttribute中的Name参数定义。

2. Namespace可以通过DataContractAttribute中的NameSpace参数定义。

3. 对象的成员只能以XML Element的形式被序列化。

4. 对象成员对应的XML Element在XML出现的位置可以通过DataMemberAttribute的Order参数来定义。

5. 对象成员对应的Element的名称可以通过DataMemberAttribute中的Name定义。

6. 如果不希望某个成员输出到XML中,可以去掉成员对应的DataMemberAttribute Attribute。

此外DataMemberAttribute还有连个额外的参数:

1. IsRequired:制定该成员为必须的,如果通过工具生成XSD的话,对应的Element的minOccur=“1”

2. EmitDefaultValue:制定是否输入没有赋值的成员(值为默认值)是否出现在XML中。

注:因为WCF中使用DataContractSerializer进行序列化和反序列化的,由于DataContractSerializer进行序列化和反序列化时,都必须事先确定对象的类型。如果被序列化对象或反序列化生成的对象包含不可知的类型,序列化或反序列化将失败。所以为了保证DataContractSerializer正常的序列化和反序列化,需要将“未知”类型加入DataContractSerializer“已知”类型列表中。可以通过两个特性设置:KnownTypeAttribute和ServiceKnownTypeAttribute。KnownTypeAttribute应用于数据契约中,用于设置继承于该数据契约类型的子数据契约,或引用其他的契约类型。ServiceKnownTypeAttribute既可以应用于服务契约的接口和方法上,还可以应用在服务实现的类和方法上,应用在不同的目标元素,决定了定义已知类型的作用范围

 

使用XmlSerializer类生成的XML文件与原始对象之间的映射关系如下(默认情况):

1.Root Element被指定为类名。

2.不会再Root Element中添加相应的Namaspace。
3.对象成员以XML Element的形式输出。
4.对象成员出现的顺利和在Type定义的顺序一致。
5.只有Public Field和可读可写得Proppery才会被序列化到XML中——比如定义在XMLProduct中的internal string ProducingArea没有出现在XML中。
6.Type定义的时候不需要运用任何Attribute。

可以通过XML相关的一些Attribute来生成所需的XML 结构

1.Root Element名称之后能为类名。

2.可以在Type上运用XMLRoot,通过Namaspace参数在Root Element指定Namespace。
3.可以通过在类成员上运用XMLElement Attribute和XMLAttribute Attribute指定对象成员转化成XMLElement还是XMLAttribute。并且可以通过NameSpace参数定义4.Namespace。
5.可以在XMLElement或者XMLAttribute Attribute 通过Order参数指定成员在XML出现的位置。
6.可以通过XmlIgnore attribute阻止对象成员被序列化。

两种不同的Serializer区别:

特性

XMLSerializer

DataContractSerializer

默认Mapping

所有Public Field和可读可写Property

所有DataMember Filed、Property

是否需要Attribute

不需要

DataContract DataMember或者Serializable

成员的默认次序

Type中定义的顺序

字母排序

兼容性

.asmx

Remoting

Deserialzation

调用默认构造函数

不会调用

 

 

该篇文章参考和引用了以下作者的文章内容:

 

文章同步发表于我的个人网站:

本文转自 梦在旅途 博客园博客,原文链接:http://www.cnblogs.com/zuowj/p/4366946.html  ,如需转载请自行联系原作者

你可能感兴趣的文章
UIProgressView的详细使用
查看>>
Silverlight实用窍门系列:70.Silverlight的视觉状态组VisualStateGroup
查看>>
照片筛选与上传功能
查看>>
Hello ZED
查看>>
常见web攻击方式
查看>>
hdu 4472
查看>>
oracle存储过程中is和as区别
查看>>
windows 2003 群集
查看>>
几个gcc的扩展功能
查看>>
Spark一个简单案例
查看>>
关于结构体占用空间大小总结(#pragma pack的使用)
查看>>
通过浏览器查看nginx服务器状态配置方法
查看>>
shell简介
查看>>
android 使用WebView 支持播放优酷视频,土豆视频
查看>>
怎么用secureCRT连接Linux
查看>>
C# 使用WinRar命令压缩和解压缩
查看>>
linux学习笔记一----------文件相关操作
查看>>
Mono for Android 优势与劣势
查看>>
服务器端开发技术
查看>>
Python3中urllib详细使用方法(header,代理,超时,认证,异常处理)
查看>>