WSDL - Panduan Cepat

WSDL adalah singkatan dari Web Services Description Language. Ini adalah format standar untuk menggambarkan layanan web. WSDL dikembangkan bersama oleh Microsoft dan IBM.

Fitur WSDL

  • WSDL adalah protokol berbasis XML untuk pertukaran informasi dalam lingkungan terdesentralisasi dan terdistribusi.

  • Definisi WSDL menjelaskan cara mengakses layanan web dan operasi apa yang akan dilakukannya.

  • WSDL adalah bahasa untuk menjelaskan cara berinteraksi dengan layanan berbasis XML.

  • WSDL adalah bagian integral dari Deskripsi Universal, Penemuan, dan Integrasi (UDDI), sebuah registri bisnis di seluruh dunia berbasis XML.

  • WSDL adalah bahasa yang digunakan UDDI.

  • WSDL diucapkan sebagai 'wiz-dull' dan dieja sebagai 'WSD-L'.

Penggunaan WSDL

WSDL sering digunakan dalam kombinasi dengan SOAP dan XML Schema untuk menyediakan layanan web melalui Internet. Program klien yang terhubung ke layanan web dapat membaca WSDL untuk menentukan fungsi apa yang tersedia di server. Setiap tipe data khusus yang digunakan disematkan dalam file WSDL dalam bentuk Skema XML. Klien kemudian dapat menggunakan SOAP untuk benar-benar memanggil salah satu fungsi yang terdaftar di WSDL.

Sejarah WSDL

WSDL 1.1 diserahkan sebagai Catatan W3C oleh Ariba, IBM, dan Microsoft untuk menjelaskan layanan untuk Aktivitas XML W3C pada Protokol XML pada Maret 2001.

WSDL 1.1 belum didukung oleh World Wide Web Consortium (W3C), namun baru saja merilis draf untuk versi 2.0 yang akan menjadi rekomendasi (standar resmi), dan dengan demikian didukung oleh W3C.

WSDL memecah layanan web menjadi tiga elemen spesifik dan dapat diidentifikasi yang dapat digabungkan atau digunakan kembali setelah ditentukan.

Tiga elemen utama WSDL yang dapat didefinisikan secara terpisah adalah -

  • Types
  • Operations
  • Binding

Dokumen WSDL memiliki berbagai elemen, tetapi mereka terkandung dalam tiga elemen utama ini, yang dapat dikembangkan sebagai dokumen terpisah dan kemudian dapat digabungkan atau digunakan kembali untuk membentuk file WSDL yang lengkap.

Elemen WSDL

Dokumen WSDL berisi elemen berikut -

  • Definition- Ini adalah elemen root dari semua dokumen WSDL. Ini mendefinisikan nama layanan web, mendeklarasikan beberapa namespace yang digunakan di seluruh sisa dokumen, dan berisi semua elemen layanan yang dijelaskan di sini.

  • Data types - Tipe data yang akan digunakan dalam pesan dalam bentuk skema XML.

  • Message - Ini adalah definisi abstrak dari data, dalam bentuk pesan yang disajikan baik sebagai keseluruhan dokumen atau sebagai argumen untuk dipetakan ke pemanggilan metode.

  • Operation - Ini adalah definisi abstrak dari operasi untuk pesan, seperti penamaan metode, antrian pesan, atau proses bisnis, yang akan menerima dan memproses pesan.

  • Port type- Ini adalah sekumpulan operasi abstrak yang dipetakan ke satu atau lebih titik akhir, mendefinisikan kumpulan operasi untuk pengikatan; kumpulan operasi, karena abstrak, dapat dipetakan ke beberapa transportasi melalui berbagai binding.

  • Binding - Ini adalah protokol konkret dan format data untuk operasi dan pesan yang ditentukan untuk jenis port tertentu.

  • Port - Ini adalah kombinasi dari pengikatan dan alamat jaringan, memberikan alamat target komunikasi layanan.

  • Service- Ini adalah kumpulan titik akhir terkait yang mencakup definisi layanan dalam file; layanan memetakan binding ke port dan menyertakan definisi ekstensibilitas apa pun.

Selain elemen utama ini, spesifikasi WSDL juga mendefinisikan elemen utilitas berikut -

  • Documentation - Elemen ini digunakan untuk menyediakan dokumentasi yang dapat dibaca manusia dan dapat dimasukkan ke dalam elemen WSDL lainnya.

  • Import - Elemen ini digunakan untuk mengimpor dokumen WSDL atau Skema XML lainnya.

NOTE - Suku cadang WSDL biasanya dibuat secara otomatis menggunakan alat berbasis layanan web.

Struktur Dokumen WSDL

Struktur utama dokumen WSDL terlihat seperti ini -

<definitions>
   <types>
      definition of types........
   </types>

   <message>
      definition of a message....
   </message>

   <portType>
      <operation>
         definition of a operation.......  
      </operation>
   </portType>

   <binding>
      definition of a binding....
   </binding>

   <service>
      definition of a service....
   </service>
</definitions>

Dokumen WSDL juga dapat berisi elemen lain, seperti elemen ekstensi dan elemen layanan yang memungkinkan untuk mengelompokkan definisi beberapa layanan web dalam satu dokumen WSDL.

Lanjutkan lebih jauh untuk menganalisis contoh Dokumen WSDL.

Diberikan di bawah ini adalah file WSDL yang disediakan untuk mendemonstrasikan program WSDL sederhana.

Mari kita asumsikan layanan menyediakan satu fungsi yang tersedia untuk umum, yang disebut sayHello . Fungsi ini mengharapkan parameter string tunggal dan mengembalikan salam string tunggal. Misalnya, jika Anda melewatkan parameter dunia maka fungsi layanan sayHello mengembalikan salam, "Halo, dunia!".

Contoh

Isi file HelloService.wsdl -

<definitions name = "HelloService"
   targetNamespace = "http://www.examples.com/wsdl/HelloService.wsdl"
   xmlns = "http://schemas.xmlsoap.org/wsdl/"
   xmlns:soap = "http://schemas.xmlsoap.org/wsdl/soap/"
   xmlns:tns = "http://www.examples.com/wsdl/HelloService.wsdl"
   xmlns:xsd = "http://www.w3.org/2001/XMLSchema">
 
   <message name = "SayHelloRequest">
      <part name = "firstName" type = "xsd:string"/>
   </message>
	
   <message name = "SayHelloResponse">
      <part name = "greeting" type = "xsd:string"/>
   </message>

   <portType name = "Hello_PortType">
      <operation name = "sayHello">
         <input message = "tns:SayHelloRequest"/>
         <output message = "tns:SayHelloResponse"/>
      </operation>
   </portType>

   <binding name = "Hello_Binding" type = "tns:Hello_PortType">
      <soap:binding style = "rpc"
         transport = "http://schemas.xmlsoap.org/soap/http"/>
      <operation name = "sayHello">
         <soap:operation soapAction = "sayHello"/>
         <input>
            <soap:body
               encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"
               namespace = "urn:examples:helloservice"
               use = "encoded"/>
         </input>
		
         <output>
            <soap:body
               encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"
               namespace = "urn:examples:helloservice"
               use = "encoded"/>
         </output>
      </operation>
   </binding>

   <service name = "Hello_Service">
      <documentation>WSDL File for HelloService</documentation>
      <port binding = "tns:Hello_Binding" name = "Hello_Port">
         <soap:address
            location = "http://www.examples.com/SayHello/" />
      </port>
   </service>
</definitions>

Analisis Contoh

  • Definitions - HelloService

  • Type - Menggunakan tipe data built-in dan mereka didefinisikan dalam XMLSchema.

  • Message -

    • sayHelloRequest - parameter firstName

    • sayHelloresponse - nilai balasan salam

  • Port Type - Operasi sayHello yang terdiri dari permintaan dan layanan respons.

  • Binding - Arah untuk menggunakan protokol transport HTTP SOAP.

  • Service - Layanan tersedia di http://www.examples.com/SayHello/

  • Port - Mengaitkan pengikatan dengan URI http://www.examples.com/SayHello/ tempat layanan yang berjalan dapat diakses.

Itu <definitions>elemen harus menjadi elemen root dari semua dokumen WSDL. Ini mendefinisikan nama layanan web.

Berikut adalah potongan kode dari bab terakhir yang menggunakan elemen definisi .

<definitions name="HelloService"
   targetNamespace="http://www.examples.com/wsdl/HelloService.wsdl"
   xmlns="http://schemas.xmlsoap.org/wsdl/"
   xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
   xmlns:tns="http://www.examples.com/wsdl/HelloService.wsdl"
   xmlns:xsd="http://www.w3.org/2001/XMLSchema">
   ................................................
</definitions>

Dari contoh di atas, kita dapat menyimpulkan bahwa definisi -

  • adalah wadah dari semua elemen lainnya.

  • menetapkan bahwa dokumen ini disebut HelloService .

  • menentukan atribut targetNamespace . The targetNamespace adalah konvensi XML Schema yang memungkinkan dokumen WSDL untuk merujuk ke dirinya sendiri. Dalam contoh ini, kami telah menetapkan targetNamespace dari http://www.examples.com/wsdl/HelloService.wsdl

  • menentukan namespace default: xmlns = http: //schemas.xmlsoap.org/wsdl/. Semua elemen tanpa awalan namespace, seperti message atau portType , diasumsikan sebagai bagian dari namespace WSDL default.

  • menentukan banyak ruang nama yang digunakan di seluruh sisa dokumen.

NOTE- Spesifikasi namespace tidak mengharuskan dokumen ada di lokasi tertentu. Poin pentingnya adalah Anda menentukan nilai yang unik, berbeda dari semua ruang nama lain yang ditentukan.

Layanan web perlu menentukan masukan dan keluarannya dan bagaimana mereka dipetakan ke dalam dan ke luar layanan. WSDL<types>elemen menangani pendefinisian tipe data yang digunakan oleh layanan web. Tipe adalah dokumen XML, atau bagian dokumen.

  • The jenis elemen menggambarkan semua jenis data yang digunakan antara klien dan server.

  • WSDL tidak terikat secara eksklusif pada sistem pengetikan tertentu.

  • WSDL menggunakan spesifikasi W3C XML Schema sebagai pilihan default untuk menentukan tipe data.

  • Jika layanan hanya menggunakan tipe sederhana bawaan Skema XML, seperti string dan integer, maka elemen tipe tidak diperlukan.

  • WSDL memungkinkan tipe untuk didefinisikan dalam elemen terpisah sehingga tipe dapat digunakan kembali dengan beberapa layanan web.

Berikut adalah potongan kode yang diambil dari spesifikasi W3C. Kode ini menggambarkan bagaimana elemen tipe dapat digunakan dalam WSDL.

<types>
   <schema targetNamespace = "http://example.com/stockquote.xsd"
      xmlns = "http://www.w3.org/2000/10/XMLSchema">
		
      <element name = "TradePriceRequest">
         <complexType>
            <all>
               <element name = "tickerSymbol" type = "string"/>
            </all>
         </complexType>
      </element>
		
      <element name = "TradePrice">
         <complexType>
            <all>
               <element name = "price" type = "float"/>
            </all>
         </complexType>
      </element>
		
   </schema>
</types>

Tipe data mengatasi masalah pengidentifikasian tipe data dan format yang ingin Anda gunakan dengan layanan web Anda. Jenis informasi dibagikan antara pengirim dan penerima. Oleh karena itu, penerima pesan memerlukan akses ke informasi yang Anda gunakan untuk menyandikan data Anda dan harus memahami cara mendekode data.

Itu <message> elemen menggambarkan data yang dipertukarkan antara penyedia layanan web dan konsumen.

  • Setiap Layanan Web memiliki dua pesan: masukan dan keluaran.

  • Input menggambarkan parameter untuk web service dan output menggambarkan data yang dikembalikan dari web service.

  • Setiap pesan berisi nol atau lebih <part> parameter, satu untuk setiap parameter fungsi layanan web.

  • Setiap <part> asosiasi parameter dengan tipe konkret yang ditentukan dalam <types> elemen kontainer.

Mari kita ambil sebagian kode dari bab Contoh WSDL -

<message name = "SayHelloRequest">
   <part name = "firstName" type = "xsd:string"/>
</message>

<message name = "SayHelloResponse">
   <part name = "greeting" type = "xsd:string"/>
</message>

Di sini, dua elemen pesan didefinisikan. Yang pertama mewakili pesan permintaan SayHelloRequest , dan yang kedua mewakili pesan respons SayHelloResponse .

Setiap pesan ini berisi satu elemen bagian. Untuk permintaan tersebut, bagian tersebut menentukan parameter fungsi; dalam kasus ini, kami menetapkan satu parameter firstName . Untuk responnya, bagian tersebut menentukan nilai-nilai pengembalian fungsi; dalam kasus ini, kami menetapkan nilai pengembalian salam tunggal.

Itu <portType> elemen menggabungkan beberapa elemen pesan untuk membentuk operasi satu arah atau bolak-balik yang lengkap.

Misalnya, a <portType>dapat menggabungkan satu permintaan dan satu pesan tanggapan ke dalam satu operasi permintaan / tanggapan. Ini paling sering digunakan dalam layanan SOAP. PortType dapat menentukan beberapa operasi.

Mari kita ambil sebagian kode dari bab Contoh WSDL -

<portType name = "Hello_PortType">
   <operation name = "sayHello">
      <input message = "tns:SayHelloRequest"/>
      <output message = "tns:SayHelloResponse"/>
   </operation>
</portType>
  • Elemen portType mendefinisikan satu operasi, yang disebut sayHello .

  • Operasi ini terdiri dari satu pesan masukan SayHelloRequest dan

  • output pesan SayHelloResponse .

Pola Operasi

WSDL mendukung empat pola operasi dasar -

Satu arah

Layanan menerima pesan. Oleh karena itu, operasi tersebut memiliki satu elemen masukan . Tata bahasa untuk operasi satu arah adalah -

<wsdl:definitions .... > 
   <wsdl:portType .... > *
      <wsdl:operation name = "nmtoken">
         <wsdl:input name = "nmtoken"? message = "qname"/>
      </wsdl:operation>
   </wsdl:portType >
</wsdl:definitions>

Respon permintaan

Layanan menerima pesan dan mengirimkan tanggapan. Oleh karena itu, operasi tersebut memiliki satu elemen masukan , diikuti oleh satu elemen keluaran . Untuk merangkum kesalahan, elemen kesalahan opsional juga dapat ditentukan. Tata bahasa untuk operasi permintaan-respons adalah -

<wsdl:definitions .... >
   <wsdl:portType .... > *
      <wsdl:operation name = "nmtoken" parameterOrder = "nmtokens">
         <wsdl:input name = "nmtoken"? message = "qname"/>
         <wsdl:output name = "nmtoken"? message = "qname"/>
         <wsdl:fault name = "nmtoken" message = "qname"/>*
      </wsdl:operation>
   </wsdl:portType>
</wsdl:definitions>

Ajukan tanggapan

Layanan mengirim pesan dan menerima tanggapan. Oleh karena itu, operasi tersebut memiliki satu elemen keluaran , diikuti oleh satu elemen masukan . Untuk merangkum kesalahan, elemen kesalahan opsional juga dapat ditentukan. Tata bahasa untuk operasi respons-solicit adalah -

<wsdl:definitions .... >
   <wsdl:portType .... > *
      <wsdl:operation name = "nmtoken" parameterOrder = "nmtokens">
         <wsdl:output name = "nmtoken"? message = "qname"/>
         <wsdl:input name = "nmtoken"? message = "qname"/>
         <wsdl:fault name = "nmtoken" message = "qname"/>*
      </wsdl:operation>
   </wsdl:portType >
</wsdl:definitions>

Pemberitahuan

Layanan mengirimkan pesan. Oleh karena itu, operasi tersebut memiliki elemen keluaran tunggal . Berikut adalah tata bahasa untuk operasi notifikasi -

<wsdl:definitions .... >
   <wsdl:portType .... > *
      <wsdl:operation name = "nmtoken">
         <wsdl:output name = "nmtoken"? message = "qname"/>
      </wsdl:operation>
   </wsdl:portType>
</wsdl:definitions>

Itu <binding>elemen memberikan detail spesifik tentang bagaimana operasi portType sebenarnya akan dikirim melalui kabel.

  • Binding dapat tersedia melalui beberapa transport termasuk HTTP GET, HTTP POST, atau SOAP.

  • Binding memberikan informasi konkret tentang protokol apa yang digunakan untuk mentransfer operasi portType .

  • Binding memberikan informasi lokasi layanan.

  • Untuk protokol SOAP, pengikatannya adalah <soap:binding>, dan transport adalah pesan SOAP di atas protokol HTTP.

  • Anda dapat menentukan beberapa binding untuk satu portType .

Elemen pengikat memiliki dua atribut: atribut nama dan tipe .

<binding name = "Hello_Binding" type = "tns:Hello_PortType">

The Nama atribut mendefinisikan nama mengikat, dan jenis atribut poin ke port untuk mengikat, dalam hal ini "TNS: Hello_PortType" port.

SOAP Binding

WSDL 1.1 menyertakan ekstensi built-in untuk SOAP 1.1. Ini memungkinkan Anda untuk menentukan detail khusus SOAP termasuk header SOAP, gaya pengkodean SOAP, dan header HTTP SOAPAction. Elemen ekstensi SOAP meliputi:

  • soap:binding
  • soap:operation
  • soap:body

sabun: mengikat

Elemen ini menunjukkan bahwa pengikatan akan tersedia melalui SOAP. The gaya atribut menunjukkan gaya keseluruhan format pesan SOAP. Nilai gaya rpc menentukan format RPC.

The transportasi atribut menunjukkan transportasi dari pesan SOAP. Nilai http://schemas.xmlsoap.org/soap/http menunjukkan transport HTTP SOAP, sedangkan http://schemas.xmlsoap.org/soap/smtp menunjukkan transport SOAP SMTP.

sabun: operasi

Elemen ini menunjukkan pengikatan operasi tertentu ke implementasi SOAP tertentu. The SOAPAction menspesifikasikan atribut bahwa SOAPAction HTTP header yang digunakan untuk mengidentifikasi layanan.

sabun: tubuh

Elemen ini memungkinkan Anda menentukan detail pesan input dan output. Dalam kasus HelloWorld, elemen body menentukan gaya pengkodean SOAP dan URN namespace yang terkait dengan layanan yang ditentukan.

Berikut adalah potongan kode dari bab Contoh -

<binding name = "Hello_Binding" type = "tns:Hello_PortType">
   <soap:binding style = "rpc" transport = "http://schemas.xmlsoap.org/soap/http"/>
   <operation name = "sayHello">
      <soap:operation soapAction = "sayHello"/>
			
      <input>
         <soap:body
            encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"
            namespace = "urn:examples:helloservice" use = "encoded"/>
      </input>
			
      <output>
         <soap:body
            encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"
            namespace = "urn:examples:helloservice" use = "encoded"/>
      </output>
   </operation>
</binding>

SEBUAH <port> elemen mendefinisikan titik akhir individu dengan menentukan satu alamat untuk pengikatan.

Berikut adalah tata bahasa untuk menentukan port -

<wsdl:definitions .... >
   <wsdl:service .... > *
      <wsdl:port name = "nmtoken" binding = "qname"> *
         <-- extensibility element (1) -->
      </wsdl:port>
   </wsdl:service>
</wsdl:definitions>
  • Elemen port memiliki dua atribut: name dan binding .

  • The Nama atribut memberikan nama unik di antara semua port didefinisikan dalam dokumen melampirkan WSDL.

  • Atribut binding mengacu pada pengikatan menggunakan aturan penautan yang ditentukan oleh WSDL.

  • Elemen ekstensibilitas yang mengikat digunakan untuk menentukan informasi alamat untuk port.

  • Sebuah port TIDAK HARUS mencantumkan lebih dari satu alamat.

  • Sebuah port TIDAK HARUS menentukan informasi yang mengikat selain informasi alamat.

Ini adalah potongan kode dari bab Contoh -

<service name = "Hello_Service">
   <documentation>WSDL File for HelloService</documentation>
   <port binding = "tns:Hello_Binding" name = "Hello_Port">
      <soap:address
         location = "http://www.examples.com/SayHello/">
   </port>
</service>

Itu <service>elemen mendefinisikan port yang didukung oleh layanan web. Untuk setiap protokol yang didukung, ada satu elemen port. Elemen layanan adalah kumpulan port.

  • Klien layanan web dapat mempelajari hal berikut dari elemen layanan -

    • di mana mengakses layanan,
    • melalui port mana untuk mengakses layanan web, dan
    • bagaimana pesan komunikasi didefinisikan.
  • Elemen layanan menyertakan elemen dokumentasi untuk menyediakan dokumentasi yang dapat dibaca manusia.

Ini adalah potongan kode dari bab Contoh -

<service name = "Hello_Service">
   <documentation>WSDL File for HelloService</documentation>
   <port binding = "tns:Hello_Binding" name = "Hello_Port">
      <soap:address
         location = "http://www.examples.com/SayHello/">
   </port>
</service>

Atribut binding dari elemen port mengaitkan alamat layanan dengan elemen binding yang ditentukan dalam layanan web. Dalam contoh ini, ini adalah Hello_Binding

<binding name =" Hello_Binding" type = "tns:Hello_PortType">
   <soap:binding style = "rpc"
      transport = "http://schemas.xmlsoap.org/soap/http"/>
   <operation name = "sayHello">
      <soap:operation soapAction = "sayHello"/>
		
      <input>
         <soap:body
            encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"
            namespace = "urn:examples:helloservice" use = "encoded"/>
      </input>
			
      <output>
         <soap:body
            encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"
            namespace = "urn:examples:helloservice" use = "encoded"/>
      </output>
   </operation>
</binding>

Kami telah membahas dasar-dasar WSDL dalam tutorial ini. Langkah selanjutnya adalah mempelajari SOAP, UDDI, dan Layanan Web.

Layanan web

Layanan web adalah standar terbuka (XML, SOAP, HTTP, dll.) Aplikasi web yang berinteraksi dengan aplikasi Web lain untuk tujuan pertukaran data.

Untuk mempelajari lebih lanjut tentang Layanan Web, kunjungi Tutorial Layanan Web.

UDDI

UDDI adalah standar berbasis XML untuk mendeskripsikan, menerbitkan, dan menemukan layanan Web.

Untuk mempelajari lebih lanjut tentang UDDI, kunjungi Tutorial UDDI.

SABUN MANDI

SOAP adalah protokol berbasis XML sederhana yang memungkinkan aplikasi untuk bertukar informasi melalui HTTP.

Untuk mempelajari lebih lanjut tentang SOAP, kunjungi Tutorial SOAP.

Jika Anda tertarik untuk mendaftarkan perusahaan, situs web, atau buku Anda sebagai sumber daya WSDL, silakan hubungi di [email protected]

Daftar Spesifikasi WSDL

Specification Draft / Proposal W3C Recommendation
     
WSDL 1.1 Catatan

15. Mar 2001

 
Skenario Penggunaan WSDL

04. Jun 2002

 
Persyaratan WSDL

28. Okt 2002

 
Arsitektur WSDL

11. Feb 2004

 
Daftar Istilah WSDL

11. Feb 2004

 
Skenario Penggunaan WSDL

11. Feb 2004

 
WSDL 1.2 Bahasa Inti

11. Jun 2003

 
WSDL 1.2 Pola Pesan

11. Jun 2003

 
Pengikatan WSDL 1.2

11. Jun 2003

 
WSDL 2.0 Primer

27. Mar 2006

 
Bahasa Inti WSDL 2.0

27. Mar 2006

 
Tambahan WSDL 2.0

27. Mar 2006

 
WSDL 2.0 SOAP 1.1 Mengikat

27. Mar 2006

 
Pemetaan WSDL 2.0 RDF

18. Mei 2006

 
WS Mengatasi Inti  

09. Mei 2006

WS Mengatasi SOAP Binding  

09. Mei 2006

Arsitektur Web  

15. Des 2004