此示例演示如何序列化和反序列化与 XmlSerializer 兼容的类型。默认的 Windows Communication Foundation (WCF) 格式化程序是 DataContractSerializer 类。当无法使用 DataContractSerializer 类时,可以使用 XmlSerializer 类来序列化和反序列化类型。当需要精确控制 XML 时通常会发生这种情况 - 例如,如果某个数据必须是一个 XML 属性,而不能是 XML 元素。此外,为非 WCF 服务创建客户端时,常常会自动选择 XmlSerializer。
在此示例中,客户端是一个控制台应用程序 (.exe),服务是由 Internet 信息服务 (IIS) 承载的。
![]() |
---|
本主题的末尾介绍了此示例的设置过程和生成说明。 |
ServiceContractAttribute 和 XmlSerializerFormatAttribute 必须应用于该接口,如下面的示例代码所示。
[ServiceContract(Namespace="http://Microsoft.ServiceModel.Samples"), XmlSerializerFormat]
public interface IXmlSerializerCalculator
{
[OperationContract]
ComplexNumber Add(ComplexNumber n1, ComplexNumber n2);
[OperationContract]
ComplexNumber Subtract(ComplexNumber n1, ComplexNumber n2);
[OperationContract]
ComplexNumber Multiply(ComplexNumber n1, ComplexNumber n2);
[OperationContract]
ComplexNumber Divide(ComplexNumber n1, ComplexNumber n2);
}
ComplexNumber
类的公共成员被 XmlSerializer 序列化为 XML 属性。DataContractSerializer 不能用于创建此类 XML 实例。
public class ComplexNumber
{
private double real;
private double imaginary;
[XmlAttribute]
public double Real
{
get { return real; }
set { real = value; }
}
[XmlAttribute]
public double Imaginary
{
get { return imaginary; }
set { imaginary = value; }
}
public ComplexNumber(double real, double imaginary)
{
this.Real = real;
this.Imaginary = imaginary;
}
public ComplexNumber()
{
this.Real = 0;
this.Imaginary = 0;
}
}
服务实现计算并返回相应的结果 - 接受并返回 ComplexNumber
类型的值。
public class XmlSerializerCalculatorService : IXmlSerializerCalculator
{
public ComplexNumber Add(ComplexNumber n1, ComplexNumber n2)
{
return new ComplexNumber(n1.Real + n2.Real, n1.Imaginary +
n2.Imaginary);
}
…
}
客户端实现也使用复数。服务协定和数据类型都是在 generatedClient.cs 源文件中定义的,该文件由ServiceModel 元数据实用工具 (Svcutil.exe) 从服务元数据生成。Svcutil.exe 可以检测何时协定不能由 DataContractSerializer 序列化,在这种情况下转而发出 XmlSerializable 类型。如果要强制使用 XmlSerializer,可以将 /serializer:XmlSerializer(使用 XmlSerializer)命令选项传递给 Svcutil.exe 工具。
// Create a client.
XmlSerializerCalculatorClient client = new
XmlSerializerCalculatorClient();
// Call the Add service operation.
ComplexNumber value1 = new ComplexNumber();
value1.Real = 1;
value1.Imaginary = 2;
ComplexNumber value2 = new ComplexNumber();
value2.Real = 3;
value2.Imaginary = 4;
ComplexNumber result = client.Add(value1, value2);
Console.WriteLine("Add({0} + {1}i, {2} + {3}i) = {4} + {5}i",
value1.Real, value1.Imaginary, value2.Real, value2.Imaginary, result.Real, result.Imaginary);
…
}
运行示例时,操作请求和响应将显示在客户端控制台窗口中。在客户端窗口中按 Enter 可以关闭客户端。
Add(1 + 2i, 3 + 4i) = 4 + 6i
Subtract(1 + 2i, 3 + 4i) = -2 + -2i
Multiply(2 + 3i, 4 + 7i) = -13 + 26i
Divide(3 + 7i, 5 + -2i) = 0.0344827586206897 + 1.41379310344828i
Press <ENTER> to terminate client.
设置、生成和运行示例
若要生成 C# 或 Visual Basic .NET 版本的解决方案,请按照生成 Windows Communication Foundation 示例中的说明进行操作。
若要用单机配置或跨计算机配置来运行示例,请按照Running the Windows Communication Foundation Samples中的说明进行操作。
![]() |
---|
您的计算机上可能已安装这些示例。在继续操作之前,请先检查以下(默认)目录:
<安装驱动器>:\WF_WCF_Samples
如果此目录不存在,请访问针对 .NET Framework 4 的 Windows Communication Foundation (WCF) 和 Windows Workflow Foundation (WF) 示例(可能为英文网页),下载所有 Windows Communication Foundation (WCF) 和 WF 示例。此示例位于以下目录。
<安装驱动器>:\WF_WCF_Samples\WCF\Basic\Client\Interop\XmlSerializer
|