A Web service is a method of communication between two electronic devices over a
network. It is a software function provided at a network address over the Web with the service
always on as in the concept of utility computing. The W3C defines a Web service generally
as:a software system designed to support interoperable machine-to-machine interaction over a
network.[1]
The W3C Web Services Architecture Working Group defined a Web Services Architecture,
requiring a specific implementation of a "Web service." In this:
[a Web service] has an interface described in a machine-processable format (specifically
WSDL). Other systems interact with the Web service in a manner prescribed by its
description using SOAP (Simple Object Access Protocol) messages, typically conveyed using
HTTP with an XML serialization in conjunction with other Web-related standards.[1]
Most Web services do not adopt this complex architecture.[citation needed] This article describes it
in more detail.
The W3C also states:
We can identify two major classes of Web services:
REST-compliant Web services, in which the primary purpose of the service is
to manipulate representations of Web resources using a uniform set of stateless
operations.
Arbitrary Web services, in which the service may expose an arbitrary set of
operations.[2]
Contents
1 Explanation
2 Web API
3 Automated design methods
4 Web services that use markup languages
5 Criticisms
6 Regression Testing of Web service
7 Web Service Change Management
8 See also
9 References
10 External links
Explanation
Many organizations use multiple software systems for management. Different software
systems often need to exchange data with each other, and a Web service is a method of
communication that allows two software systems to exchange this data over the internet. The
software system that requests data is called a service requester, whereas the software system
that would process the request and provide the data is called a service provider.
Different software might be built using different programming languages, and hence there is a
need for a method of data exchange that doesn't depend upon a particular programming
language. Most types of software can, however, interpret XML tags. Thus, Web services can
use XML files for data exchange.
Rules for communication between different systems need to be defined, such as:
How one system can request data from another system
Which specific parameters are needed in the data request
What would be the structure of the data produced. Normally, data is exchanged in
XML files, and the structure of the XML file is validated against an .xsd file.
What error messages to display when a certain rule for communication is not
observed, to make troubleshooting easier
All of these rules for communication are defined in a file called WSDL (Web Services
Description Language), which has the extension .wsdl.
Web services architecture: the service provider sends a WSDL file to UDDI. The service
requester contacts UDDI to find out who is the provider for the data it needs, and then it
contacts the service provider using the SOAP protocol. The service provider validates the
service request and sends structured data in an XML file, using the SOAP protocol. This
XML file would be validated again by the service requester using an XSD file.
A directory called UDDI (Universal Description, Discovery and Integration) defines which
software system should be contacted for which type of data. So when one software system
needs one particular report/data, it would go to the UDDI and find out which other system it
can contact for receiving that data. Once the software system finds out which other system it
should contact, it would then contact that system using a special protocol called SOAP
(Simple Object Access Protocol). The service provider system would first of all validate the
data request by referring to the WSDL file, and then process the request and send the data
under the SOAP protocol.
Web API
Web services in a service-oriented architecture.
A Web API is a development in Web services where emphasis has been moving to simpler
representational state transfer (REST) based communications.[3] RESTful APIs do not require
XML-based Web service protocols (SOAP and WSDL) to support their interfaces.
Automated design methods
Automated tools can aid in the creation of a Web service. For services using WSDL, it is
possible to either automatically generate WSDL for existing classes (a bottom-up model) or to
generate a class skeleton given existing WSDL (a top-down model).
A developer using a bottom-up model writes implementing classes first (in some
programming language), and then uses a WSDL generating tool to expose methods
from these classes as a Web service. This is simpler to develop but may be harder to
maintain if the original classes are subject to frequent change.[4]
A developer using a top-down model writes the WSDL document first and then uses a
code generating tool to produce the class skeleton, to be completed as necessary. This
model is generally considered more difficult but can produce cleaner designs and is
generally more resistant to change. As long as the message formats between sender
and receiver do not change, changes in the sender and receiver themselves do not
affect the Web service. The technique is also referred to as contract first since the
WSDL (or contract between sender and receiver) is the starting point.[5]
A developer using a Subset WSDL (SWSDL)[6] (i.e. a WSDL with the subset
operation in the original WSDL) can perform web service testing and top down
development.