Channel Factory
A ChannelFactory minta bemutatja, hogy egy ügyfélalkalmazás hogyan hozhat létre egy csatornát az osztálysal a ChannelFactory generált ügyfél helyett. Ez a minta a számológép szolgáltatást megvalósító első lépéseken alapul.
Feljegyzés
A minta telepítési eljárása és összeállítási utasításai a témakör végén találhatók.
Ez a minta az ChannelFactory<TChannel> osztály használatával hoz létre egy csatornát egy szolgáltatásvégponthoz. Egy szolgáltatásvégpont csatornájának létrehozásához általában létrehoz egy ügyféltípust a ServiceModel Metaadat-segédprogrammal (Svcutil.exe), és létrehozza a létrehozott típus egy példányát. A csatornát az osztály használatával is létrehozhatja, ahogyan az ebben a ChannelFactory<TChannel> példában is látható. Az alábbi mintakód által létrehozott szolgáltatás megegyezik az első lépésekben szereplő szolgáltatással.
EndpointAddress address = new EndpointAddress("http://localhost/servicemodelsamples/service.svc");
WSHttpBinding binding = new WSHttpBinding();
ChannelFactory<ICalculator> factory = new
ChannelFactory<ICalculator>(binding, address);
ICalculator channel = factory.CreateChannel();
Fontos
Ha ezt a mintát gépközi forgatókönyvben futtatja, az előző kódban szereplő "localhost" helyére a szolgáltatást futtató gép teljes nevét kell lecserélni. Ez a minta nem használja a konfigurációt a végpontcím beállításához, ezért ezt kódban kell elvégezni.
A csatorna létrehozása után a szolgáltatásműveletek ugyanúgy meghívhatók, mint egy generált ügyfél esetében.
// Call the Add service operation.
double value1 = 100.00D;
double value2 = 15.99D;
double result = channel.Add(value1, value2);
Console.WriteLine("Add({0},{1}) = {2}", value1, value2, result);
A csatorna bezárásához először egy IClientChannel interfészre kell leadni. Ennek az az oka, hogy a létrehozott csatorna az ügyfélalkalmazásban deklarálva van a ICalculator
felülettel, amelynek metódusai hasonlók Add
, Subtract
de nem Close
. A Close
metódus a ICommunicationObject felületről származik.
// Close the channel.
((IClientChannel)client).Close();
A minta futtatásakor a műveleti kérelmek és a válaszok megjelennek az ügyfélkonzol ablakában. Az ügyfélalkalmazás leállításához nyomja le az ENTER billentyűt az ügyfélablakban.
Add(100,15.99) = 115.99
Subtract(145,76.54) = 68.46
Multiply(9,81.25) = 731.25
Divide(22,7) = 3.14285714285714
Press <ENTER> to terminate client.
A minta beállítása, összeállítása és futtatása
Győződjön meg arról, hogy elvégezte a Windows Communication Foundation-minták egyszeri beállítási eljárását.
A megoldás C# vagy Visual Basic .NET kiadásának létrehozásához kövesse a Windows Communication Foundation-minták készítéséhez szükséges utasításokat. Vegye figyelembe, hogy ez a minta nem engedélyezi a metaadatok közzétételét. Először engedélyeznie kell a metaadatok közzétételét ehhez a mintához az ügyféltípus újragenerálásához.
Ha a mintát egy vagy több gép közötti konfigurációban szeretné futtatni, kövesse a Windows Communication Foundation-minták futtatásával kapcsolatos utasításokat.
A mintagép futtatása
Cserélje le a "localhost" szót a következő kódban a szolgáltatást futtató gép teljes nevére.
EndpointAddress address = new EndpointAddress("http://localhost/servicemodelsamples/service.svc");