Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
XmlSerializer ukázka ukazuje, jak serializovat a deserializovat typy, které jsou kompatibilní s XmlSerializer. Výchozí formátovací modul WCF (Windows Communication Foundation) je DataContractSerializer třída. Třídu XmlSerializer lze použít k serializaci a deserializaci typů, pokud nelze použít třídu DataContractSerializer. To je často případ, kdy je vyžadována přesná kontrola XML – například pokud část dat musí být atribut XML, nikoli element XML. Často se XmlSerializer také automaticky vybírá při vytváření klientů pro služby, které nejsou službami WCF.
V této ukázce je klient konzolovou aplikací (.exe) a služba je hostovaná internetovou informační službou (IIS).
Poznámka:
Postup nastavení a pokyny k sestavení pro tuto ukázku najdete na konci tohoto tématu.
ServiceContractAttribute a XmlSerializerFormatAttribute se musí použít na rozhraní, jak je znázorněno v následujícím vzorovém kódu.
[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);
}
Veřejné členy ComplexNumber třídy jsou serializovány XmlSerializer jako atributy XML. Nelze DataContractSerializer použít k vytvoření tohoto typu instance 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;
}
}
Implementace služby vypočítá a vrátí odpovídající výsledek – přijímá a vrací hodnoty ComplexNumber typu.
public class XmlSerializerCalculatorService : IXmlSerializerCalculator
{
public ComplexNumber Add(ComplexNumber n1, ComplexNumber n2)
{
return new ComplexNumber(n1.Real + n2.Real, n1.Imaginary +
n2.Imaginary);
}
…
}
Implementace klienta také používá komplexní čísla. Kontrakt služby i datové typy jsou definovány ve zdrojovém souboru generatedClient.cs, který byl generován nástrojem ServiceModel Metadata Utility (Svcutil.exe) z metadat služby. Svcutil.exe může zjistit, kdy kontrakt není serializovatelný DataContractSerializer a v tomto případě se vrátí k vydávání XmlSerializable typů. Chcete-li vynutit použití XmlSerializer, můžete zadat příkazovou možnost /serializer:XmlSerializer (použijte XmlSerializer) pomocí nástroje 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);
…
}
Při spuštění ukázky se požadavky na operace a odpovědi zobrazí v okně konzoly klienta. Stisknutím klávesy ENTER v okně klienta klienta ukončete klienta.
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.
Jak nastavit, sestavit a spustit ukázku
Ujistěte se, že jste provedli instalační proceduru One-Time pro ukázky Windows Communication Foundation.
Pokud chcete sestavit verzi C# nebo Visual Basic .NET řešení, postupujte podle pokynů v Sestavení ukázek Windows Communication Foundation.
Pokud chcete spustit ukázku v konfiguraci pro jeden počítač nebo pro více počítačů, postupujte podle pokynů v Spuštění ukázek Windows Communication Foundation.