WCF Nedir ? (Windows Communication Foundation)

  • .Net Framework 3.0 ile birlikte gelmiştir.
  • Farklı platformlar arasında iletişim sağlamak ve Service Oriented Architecture – SOA için uygulamalar geliştirmek için geliştirilmiştir.
  • Web servisini yayımlamak için HTTP, WSHTTP gibi protokoller kullanılabilir.
  • Servisler IIS üzerinde http kuralları kullanılarak yayınlanabilir, ya da Windows üzerinde TCP - Pipe gibi yöntemlerle barındırılabilir.

 

WCF ana hatlarıyla 3 kısma ayrılır (A-B-C)

1.   Address

-        Bir servisin nerede olduğunu, hangi protokol ile yayınlama yaptığını bildiren bilgidir. Aktif olarak çalışan her servis WCF’ye göre eşsiz bir adrese sahip olmalıdır. 

 

WCF servisine ulaşabilmek için kullanılabilecek protokoller;

-        HTTP (http:// veya https://)

-        TCP (net.tcp://)

-        Peer 2 Peer (net.p2p://)

-        IPC (net.pipe://)

-        MSMQ (net.msmq://)

2.   Binding

-        Uygulamalar tarafından veri göndermek ya da veri almak için servis ile nasıl iletişime geçileceğinin tanımlandığı bölüm. WCF hizmetleri için kullanılabilecek ön tanımlı binding’ ler;

 

 

3.   Contract

-        Bir servisin ne iş yaptığının bilinmesinde rol oynar. Bazı sözleşmeler şunlardır:

·        Servis sözleşmesi (Service Contract): Servis ile yaratılacak olan operasyonların tanımlanmasında kullanılır.

 
 [ServiceContract]

   public interface IService1

   { }
 

·        Veri Sözleşmesi (Data Contract): Servis içerisinde bulunan class’ları tanımlamak için kullanılır. Sınıfların üyeleri Data Member olarak tanımlanır.

 

   [DataContract]
   public class MyClass
   { }
 
            [DataMember]

            public string StringValue

            {

               get { return stringValue; }

               set { stringValue = value; }

            }


 

·        Hata Sözleşmesi (Fault Contract): Servis tarafından tanımlanacak olan hatalar bu yolla tanımlanır.

·        Mesaj Sözleşmesi (Message Contract): Servisler ile mesajlar arasında iletişim kurulmasını sağlar.

 

Endpoints

Clients ile Host arasındaki iletişimi şağlamak için kullanılan bir arayüzdür. Her endpoint’in kendi adresi vardır ve bu adresin benzersiz olması için servisin kendi ana adresine eklenmektedir. Bir WCF servisini aslında endpoint topluluğu olarak düşünebiliriz.

Behaviors

Servis davranışları, servislerin veya istemcilerin fonksiyonelliklerini arttırmak için kullanılırlar. Örneğin servislerin metadata bilgisinin paylaşılıp paylaşılamayacağı, ekstra güvenlik eklenmesi, tracking tracing logging gibi bilgilerin tutulması, parametre ve mesajların validasyonları, hata alındığı durumlarda detayları exception bilgisinin istemci tarafına gönderilip gönderilemeyeceği gibi.

 

Yeni bir WCF hizmeti tanımlarken ilk olarak sunulması hedeflenen fonsiyonaliteler netleştirilip ve bir contract ile duyurulur. Bu contract’ lar interface’lerin içerisine yazılırlar.

  [ServiceContract] //Contrat’ın bir hizmette kullanılacağını belirtmek için interface’in üst kısmına ServiceContract yazılır
    public interface IServiceImpl
    {
        [OperationContract] //Oluşturulan metodların service tarafından kullanılabilmesi için uygulanan etikettir.
        bool SaveData(string Val); //string tipinde bir parametre alarak gelen değeri kaydeden bir metod.
 
//XML ya da JSON formatında internet üzerinde ya da local’de veri yayınlamak istediğimizde aşağıda bulunan kodlara benzer yapılar kullanılır.
        [OperationContract]
        [WebInvoke(Method = "GET",  //GET metodunun kullanılacağı belirtildi.
            ResponseFormat = WebMessageFormat.Xml, //Geriye dönen veri XML formatındadır.
            BodyStyle = WebMessageBodyStyle.Wrapped,
            UriTemplate = "xml")]      //Url’de bu metodun çağırılmasını sağlayacak string
        List<Employee> XMLData();       //Geri dönüş tipi ile birlikte Metod ismi.
    }

 
//Belirtilmiş olan kontratlara uygun metodlar class içerisine yazılır.
namespace MyService
{
    public class ServiceImpl : IServiceImpl
    {
        public bool SaveData(string val)  //interface içerisinde tanımlanan servis kontratı.
        {
            return true;
        }
 
        public List<Employee> XMLData()//interface içerisinde tanımlanan XMLData servis kontratı
        {
            return new List<Employee>();           
        }
   }
}

 

Proje içerisinde bulunan app.config/Web.config sayfaları içerisinde kullanılacak kontratlar endpoint’ ler içerisinde tanımlanır ve servis yayınlanmaya hazır hale getirilir.

<servicename="Services.ServiceImpl "behaviorConfiguration="ServiceBehaviour">
       <endpointaddress=""binding="webHttpBinding"contract="Services.IServiceImpl "behaviorConfiguration="web">
        </endpoint>
     </service>xm

     

Endpoint ile servisi hangi adres, protokol ve kontrat ile yayınlayacağımızı belirtmekteyiz.  Bu kullanım hizmet sınıfını birden fazla kontrat ile farklı farklı adres ve protokollerle yayınlayabilme olanağı sağlamaktadır.