Presentation on theme: "1 Web Services – Part I CS 236607, Spring 2008/9."— Presentation transcript:
1 Web Services – Part I CS 236607, Spring 2008/9
2 What is a Web Service? Web Service: 1. "Web services are loosely coupled software components delivered over Internet standard technologies." 2. “Software that makes services available on a network using technologies such as XML and HTTP” Service-Oriented Architecture (SOA): “Development of applications from distributed collections of smaller loosely coupled service providers” Web services support service-oriented architectures, using in particular XML and HTTP.
3 What is a Web Service? (Cont.) Self-contained, modular Web application that can be published, located and invoked across the Web A Web service can perform functions of varying complexities. Once deployed, other applications (and other Web services) can discover and invoke the deployed service
4 Why a New Framework? CORBA, DCOM, Java/RMI,... already exist XML+HTTP: platform neutral, widely accepted and utilized
Example Scenario – Online Trade Book Store The Hobbit (5) Price: 25.95 Copies in Stock: 1 The Hobbit (5) Price: 25.95 Copies in Stock: 0 Book Store The Hobbit (5) Price: 20.95 Copies in Stock: 5 Buy The Hobbit (5) How Much? 20.95 Buy it The Hobbit (5) Price: 20.95 Copies in Stock: 4 The Hobbit (5) Price: 25.95 Copies in Stock: 1 The Hobbit (5) Price: 25.95 Copies in Stock: 0
6 Why is it Difficult to Use Ordinary Web Sites as Services? Consider an application that should return the price of the book “The Hobbit” The application needs to fill the required form and launch a “browser-like” request The application needs to parse the page, based on its specific HTML structure, and retrieve the price Once the Web site changes its user interface, your program is useless How can we find new online stores?
What is the price here? How can we find this URL?
8 Calling Remote Functions Could Help It would help if we could call functions, such as: Amazon.getPrice(“The Hobbit") Amazon.buyBook(“The Hobbit", myId) getPrice(…) The Internet
9 Difficulties in Using Remote Functions For each remote function, we need to phrase a call in the specific language that is used for its implementation For each remote function, we need to contact the provider in order to find out what exactly the signature (i.e., parameters, return value, inc. the type) is On the server side, each remote function needs to listen to a server socket bound to a specific port Not in line with protection by firewalls
10 A Solution Use an agreed interface and a syntax that all applications are familiar with (e.g., XML) For example, SOAP Use HTTP to transfer data through port 80 Use a standard for publishing methods, their signatures and their usage For example, WSDL Use standard directory structures for publishing available services For example, UDDI
11 Available Web Services Examples http://seekda.com/ Google search (http://www.google.com/apis) Weather reports Stock prices Currency exchanges Sending SMS messages, faxes Prices of books in Barnes and Nobles Dictionaries And more…
12 Essential Technologies A range of protocols has been suggested in the last years. We will discuss what are commonly believed to be the essential technologies: SOAP – exchanging XML messages on a network WSDL – describing interfaces of Web services UDDI – managing registries of Web services SERVICE REGISTRY SERVICE USER (Client) SERVICE PROVIDER publish messages find
13 SOAP Used to be “Simple Object Access Protocol” but no longer an acronym...
14 What is SOAP? SOAP is a protocol for invoking Web Services SOAP is XML based In SOAP, applications may exchange information over HTTP HTTP is just one possible communication pattern supported by SOAP (e.g. SMTP)
15 SOAP Envelope... Envelope Headers: Encryption information Access control Routing ...
< soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> Euro Israel A request to services.xmethods.net:80
17 < n:getRateResponse xmlns:n='urn:xmethods-CurrencyExchange'> 5.5825 The Response
18 A SOAP Message A SOAP message is an ordinary XML document containing the following elements: Envelope – identifies the XML document as a SOAP message: required Header – contains header information: optional Body – contains call or response information: required Fault – provides information about errors that occurred while processing the message: optional
19 Special SOAP Header Attributes mustUnderstand And more Example:... gzip+base64... INITIAL SENDER INTERMEDIARY ULTIMATE RECEIVER role
20 SOAP Response on Error In loosely connected distributed systems many things can go wrong: Invalid data may be transmitted Servers may be unavailable SOAP provides a uniform way to indicate such errors.
21 Faults Example env:Sender w:InvalidBuyRequest The value of 'amount' is invalid! Værdien af 'amount' er ugyldig!
22 Protocol Binding Transmitting a SOAP message requires a communication protocol to carry the message. This is called SOAP protocol binding. Transmission protocols: HTTP, SMTP,... Message exchange patterns: request–response (for RPC) POST SOAP response (Only the response is a SOAP message) GET How will we know what To use?
27 A Recipe Server with XML and HTTP Let’s think of a Recipe Server which under an Ad hoc approach, RPC-style, it would have the following functionalities: Recipes getRecipes() Lock lockRecipe(ID) void writeRecipe(Lock,Recipe) void unlockRecipe(Lock) This is how it’s WSDL would look like (The following slides)
34 To Put It Briefly… This particular WSDL description tells us that there is a Web service at the URI http://www.widget.inc/personal/jdoe/recipeserver http://www.widget.inc/personal/jdoe/recipeserver It understands the RPC-style operations getRecipes, lockRecipe, writeRecipe, and unlockRecipe The communication uses SOAP with the SOAP HTTP binding Certain faults may occur And input and output values are required to be valid according the given schema definitions.
35 UDDI Universal Description, Discovery, and Integration
36 A Telephone Book How can you find a Web service? How can you register your Web service so that others will find it? UDDI is a mechanism for registering and discovering Web services. Think of UDDI as a telephone book
37 More about UDDI UDDI has grown from the equivalent of a simple yellow pages directory to a framework for brokering collaboration between Web services. For the applications we have considered so far, an external Web service would typically be discovered manually by the programmer and be hardwired into the application. This is known as static discovery. UDDI also targets dynamic discovery, where the application itself at runtime finds a required Web service selected on the basis of, for example, price, availability, or efficiency.
38 More about UDDI (Cont.) UDDI has as yet few applications, compared to the more widespread use of SOAP and WSDL, and most available case studies only consider static discovery.
39 Summary SOAP – A protocol for exchanging XML messages on a network (focusing on HTTP) WSDL – A language for describing Web services interfaces. UDDI – A system for managing registries of Web services
40 Resources An Introduction to XML and Web Technologies / Anders Møller and Michael I. Schwartzbach – course literature An Introduction to XML and Web Technologies / Anders Møller and Michael I. Schwartzbach W3C’s SOAP Specifications W3C’s WSDL Specifications UDDI The Web Service Interoperability Organization The Web Service Interoperability Organization HU