Web Hizmetleri - Örnekler

Web hizmeti mimarisine dayanarak, web hizmetleri uygulamasının bir parçası olarak aşağıdaki iki bileşeni oluşturuyoruz:

Servis Sağlayıcı veya Yayıncı

Bu, web hizmetinin sağlayıcısıdır. Servis sağlayıcı, servisi uygular ve İnternet veya intranet üzerinden kullanılabilir hale getirir.

.NET SDK kullanarak basit bir web hizmeti yazıp yayınlayacağız.

Hizmet İsteği Sahibi veya Tüketici

Bu, web hizmetinin herhangi bir tüketicisidir. İstekte bulunan, bir ağ bağlantısı açarak ve bir XML isteği göndererek mevcut bir web hizmetini kullanır.

Ayrıca iki web hizmeti talep edicisi de yazacağız: bir web tabanlı tüketici (ASP.NET uygulaması) ve bir başka Windows uygulama tabanlı tüketici.

Aşağıda servis sağlayıcı olarak çalışan ve uygulamaların kullanacağı web servisleri olarak iki yöntemi (add ve SayHello) ortaya koyan ilk web servis örneğimiz verilmiştir. Bu, bir web hizmeti için standart bir şablondur. .NET web hizmetleri .asmx uzantısını kullanır. Web hizmeti olarak gösterilen bir yöntemin WebMethod özniteliğine sahip olduğunu unutmayın. Bu dosyayı FirstService.asmx olarak IIS sanal dizinine kaydedin (IIS'yi yapılandırmada açıklandığı gibi; örneğin, c: \ MyWebSerces).

FirstService.asmx
<%@ WebService language = "C#" class = "FirstService" %>

using System;
using System.Web.Services;
using System.Xml.Serialization;

[WebService(Namespace = "http://localhost/MyWebServices/")]
public class FirstService : WebService{
   [WebMethod]
   public int Add(int a, int b) {
      return a + b;
   }

   [WebMethod]
   public String SayHello() {
      return "Hello World";
   }
}

Bir web servisini test etmek için yayınlanması gerekir. Bir web hizmeti intranette veya İnternette yayınlanabilir. Bu web hizmetini yerel bir makinede çalışan IIS üzerinde yayınlayacağız. IIS'yi yapılandırmakla başlayalım.

  • Başlat → Ayarlar → Denetim Masası → Yönetim araçları → İnternet Hizmetleri Yöneticisi'ni açın.

  • Varsayılan web sitesini genişletin ve sağ tıklayın; Yeni & # rarr; Sanal Dizin. Sanal Dizin Oluşturma Sihirbazı açılır. Sonrakine tıkla.

  • "Sanal Dizin Diğer Adı" ekranı açılır. Sanal dizin adını yazın. Örneğin, MyWebServices. Sonrakine tıkla.

  • "Web Sitesi İçerik Dizini" ekranı açılır.

  • Sanal dizin için dizin yolu adını girin. Örneğin, c: \ MyWebServices. Sonrakine tıkla.

  • "Erişim İzni" ekranı açılır. Ayarları ihtiyaçlarınıza göre değiştirin. Bu alıştırma için varsayılan ayarları koruyalım.

  • İleri düğmesine tıklayın. IIS yapılandırmasını tamamlar.

  • Yapılandırmayı tamamlamak için Bitir'e tıklayın.

IIS'nin doğru yapılandırılıp yapılandırılmadığını test etmek için, yukarıda oluşturulan sanal dizine (C: \ MyWebServices) bir HTML dosyası (Örneğin, x.html) kopyalayın. Şimdi, Internet Explorer'ı açın ve yazınhttp://localhost/MyWebServices/x.html. X.html dosyasını açmalıdır.

Note- Çalışmazsa, localhost'u makinenizin IP adresiyle değiştirmeyi deneyin. Hala çalışmıyorsa, IIS'nin çalışıp çalışmadığını kontrol edin; IIS ve Sanal Dizini yeniden yapılandırmanız gerekebilir.

Bu web hizmetini test etmek için, yukarıda oluşturulan IIS sanal dizinindeki (C: \ MyWebServices) FirstService.asmx'i kopyalayın. Web hizmetini Internet Explorer'da açın (http: //localhost/MyWebServices/FirstService.asmx). Web servis sayfanızı açmalıdır. Sayfada, uygulamamız tarafından web hizmetleri olarak gösterilen iki yönteme bağlantılar bulunmalıdır. Tebrikler! İlk web hizmetinizi yazdınız!

Web Hizmetini Test Etme

Az önce gördüğümüz gibi, .NET Framework'te web hizmetleri yazmak kolaydır. .NET çerçevesinde web hizmeti tüketicileri yazmak da kolaydır; ancak biraz daha karmaşık. Daha önce de belirtildiği gibi, biri web tabanlı diğeri Windows uygulama tabanlı tüketici olmak üzere iki tür hizmet tüketicisi yazacağız. İlk web hizmeti tüketicimizi yazalım.

Web Tabanlı Hizmet Tüketicisi

Aşağıda belirtildiği gibi web tabanlı bir tüketici yazın. WebApp.aspx olarak adlandırın. Bunun bir ASP.NET uygulaması olduğunu unutmayın. Bunu web hizmetinin sanal dizinine kaydedin (c: \ MyWebServices \ WebApp.axpx).

Bu uygulama, eklenecek kullanıcıdan sayı almak için kullanılan iki metin alanına sahiptir. Tıklandığında Add ve SayHello web hizmetlerini alan Execute adlı bir düğmesi vardır.

WebApp.aspx
<%@ Page Language = "C#" %>
<script runat = "server">
   void runSrvice_Click(Object sender, EventArgs e) {
      FirstService mySvc = new FirstService();
      Label1.Text = mySvc.SayHello();
      Label2.Text = mySvc.Add(Int32.Parse(txtNum1.Text),  Int32.Parse(txtNum2.Text)).ToString();
   }
</script>

<html>
   <head> </head>
   
   <body>
      <form runat = "server">
         <p>
            <em>First Number to Add </em>:
            <asp:TextBox id = "txtNum1" runat = "server" Width = "43px">4<  /asp:TextBox>
         </p>
			
         <p>
            <em>Second Number To Add </em>:
            <asp:TextBox id = "txtNum2" runat = "server" Width = "44px">5</asp:TextBox>
         </p>
			
         <p>
            <strong><u>Web Service Result -</u></strong>
         </p>
			
         <p>
            <em>Hello world Service</em> :
            <asp:Label id = "Label1" runat = "server" Font-Underline = "True">Label< /asp:Label>
         </p>

         <p>
            <em>Add Service</em> :
            & <asp:Label id = "Label2" runat = "server" Font-Underline = "True">Label</asp:Label>
         </p>
			
         <p align = "left">
            <asp:Button id = "runSrvice" onclick = "runSrvice_Click" runat = "server" Text = "Execute"></asp:Button>
         </p>
      </form>
   </body>
</html>

Tüketici oluşturulduktan sonra, tüketilecek web hizmeti için bir proxy oluşturmamız gerekiyor. Bu çalışma, eklenen bir web hizmetine başvurulduğunda bizim için Visual Studio .NET tarafından otomatik olarak yapılır. İşte izlenecek adımlar -

  • Kullanılacak Web Hizmeti için bir proxy oluşturun. Proxy, .NET SDK ile birlikte sağlanan WSDL yardımcı programı kullanılarak oluşturulur. Bu yardımcı program, Web Hizmetinden bilgi alır ve bir proxy oluşturur. Proxy yalnızca belirli bir Web Hizmeti için geçerlidir. Diğer Web Hizmetlerini kullanmanız gerekiyorsa, bu hizmet için de bir proxy oluşturmanız gerekir. Visual Studio .NET, Web Hizmeti başvurusu eklendiğinde sizin için otomatik olarak bir proxy oluşturur. .NET SDK ile sağlanan WSDL yardımcı programını kullanarak Web Hizmeti için bir proxy oluşturun. Geçerli dizinde FirstSevice.cs dosyasını oluşturacaktır. Web Hizmeti için FirstService.dll (proxy) oluşturmak için onu derlememiz gerekir.

c:> WSDL http://localhost/MyWebServices/FirstService.asmx?WSDL
c:> csc /t:library FirstService.cs
  • Derlenmiş proxy'yi Web Hizmetinin sanal dizininin (c: \ MyWebServices \ bin) bin dizinine koyun. Internet Information Services (IIS), bu dizinde proxy'yi arar.

  • Daha önce yaptığımız gibi hizmet tüketicisini yaratın. Web Hizmeti proxy'sinin bir nesnesinin tüketicide somutlaştırıldığını unutmayın. Bu vekil, hizmetle etkileşim kurmaya özen gösterir.

  • IE'de test etmek için tüketicinin URL'sini yazın (örneğin, http: //localhost/MyWebServices/WebApp.aspx).

Windows Uygulama Tabanlı Web Hizmeti Tüketicisi

Windows uygulaması tabanlı bir web hizmeti tüketicisi yazmak, diğer herhangi bir Windows uygulamasını yazmakla aynıdır. Yalnızca proxy'yi (daha önce yaptığımız) oluşturmanız ve uygulamayı derlerken bu proxy'ye başvurmanız gerekir. Web hizmetini kullanan Windows uygulamamız aşağıdadır. Bu uygulama bir web hizmeti nesnesi (tabii ki proxy) oluşturur ve üzerinde SayHello ve Add yöntemlerini çağırır.

WinApp.cs

using System;
using System.IO;

namespace SvcConsumer {
   class SvcEater {
      public static void Main(String[] args) {
         FirstService mySvc = new FirstService();
         Console.WriteLine("Calling Hello World Service: " + mySvc.SayHello());
         Console.WriteLine("Calling Add(2, 3) Service: " + mySvc.Add(2, 3).ToString());
      }
   }
}

Kullanarak derleyin c:\>csc /r:FirstService.dll WinApp.cs. WinApp.exe oluşturacaktır. Uygulamayı ve web hizmetini test etmek için çalıştırın.

Şimdi, soru ortaya çıkıyor: Bu uygulamanın gerçekten web hizmetini çağırdığından nasıl emin olabilirsiniz?

Test etmesi basit. Web hizmetine ulaşılamaması için web sunucunuzu durdurun. Şimdi, WinApp uygulamasını çalıştırın. Bir çalışma zamanı istisnasını tetikler. Şimdi web sunucusunu yeniden başlatın. İşe yaramalı.