Пример XmlSerializer
В примере XmlSerializer показано, как сериализировать и десериализировать типы, совместимые с ним XmlSerializer. По умолчанию форматировщик Windows Communication Foundation (WCF) является классом DataContractSerializer . Класс XmlSerializer может быть использован для выполнения сериализации и десериализации типов в том случае, когда не может быть использован класс DataContractSerializer. Это часто происходит, когда требуется четкий контроль над XML - например, если фрагмент данных должен быть атрибутом XML, а не XML-элементом. Кроме того, XmlSerializer часто выбирается автоматически при создании клиентов для служб, отличных от WCF.
В этом образце клиентом является консольное приложение (EXE), а служба размещается в службах 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, можно указать в средстве Svcutil.exe параметр /serializer:XmlSerializer (использование XmlSerializer).
// 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);
…
}
При выполнении примера запросы и ответы операций отображаются в окне консоли клиента. Чтобы закрыть клиент, нажмите клавишу ВВОД в окне клиента.
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.
Настройка, сборка и выполнение образца
Убедитесь, что вы выполнили процедуру однократной установки для примеров Windows Communication Foundation.
Чтобы создать выпуск решения на языке C# или Visual Basic .NET, следуйте инструкциям в разделе Building the Windows Communication Foundation Samples.
Чтобы запустить пример в конфигурации с одним или несколькими компьютерами, следуйте инструкциям в разделе "Примеры Windows Communication Foundation".