Web Services

51
Web Services Raj Sunderraman CSC 8711 Computer Science Department Georgia State University (Adapted from Mark Sapossnek (Boston Uni.) presentation)

description

Web Services. Raj Sunderraman CSC 8711 Computer Science Department Georgia State University (Adapted from Mark Sapossnek (Boston Uni.) presentation). Web Services Overview Internet Business Processes Span Companies. Web Services Overview Technology Fabric Must Span Companies Too. - PowerPoint PPT Presentation

Transcript of Web Services

Page 1: Web Services

Web Services

Raj Sunderraman

CSC 8711

Computer Science Department

Georgia State University

(Adapted from Mark Sapossnek (Boston Uni.) presentation)

Page 2: Web Services

Web Services Overview Internet Business Processes Span Companies

Page 3: Web Services

Web Services Overview Technology Fabric Must Span Companies Too

Page 4: Web Services

Companies, suppliers, partners, and customers must be able to work together Faster than ever before Over the Internet Or risk “death by isolation”

Leverage Internet cost structure

Web Services Overview Drivers

Page 5: Web Services

Web Services Overview Possible Solutions

Distributed computing Web sites (portals) Web Services

Page 6: Web Services

Web Services Overview Distributed Computing

Client/server model Doesn‘t scale Not secure

Distributed object model Components: packaging and interoperability Remoting: remote method invocation COM, CORBA, Java RMI and EJB

Not Internet-friendly Interoperability issues: poor/non-existent standards Tightly coupled: still doesn‘t scale

Page 7: Web Services

Web Services Overview Distributed Computing

3-tier Application Architecture Great way to build scalable Web applications

But such applications are silos Integration is an afterthought They can be integrated behind the firewall

Even that can be a problem They do not provide a way to integrate across the

firewall (i.e. over the Internet)

Page 8: Web Services

Mail

Calendar

News

Finance

Weather

Other

Svcs

Ads

Web Services Overview Portals

Page 9: Web Services

No standard way to expose functionality Integration is expensive and error-prone Hard to outsource Not designed to be used outside original scope The problem?

HTML is designed for presentation to people Can’t repurpose it in a general, reliable way Don’t even think about screen scraping

Web Services OverviewPortal Limitations

Page 10: Web Services

Web Services Overview What Is a Web Service?

The solution? Web Services! A Web Service exposes functionality to a consumer

Over the Internet or intranet A programmable URL Functions you can call over the Internet

Based on Web standards HTTP, XML, SOAP, WSDL, UDDI, with more to come

Can be implemented in any language on any platform Black boxes

Component-like, reusable

Page 11: Web Services

Web Services Overview What Is a Web Service?

A Web Service combines the best features of distributed computing and portals and eliminates the worst Provides a mechanism for invoking methods remotely Uses Web standards (e.g. HTTP, XML) to do so

Page 12: Web Services

Web Services Overview What Is a Web Service?

Web Services allow you to interconnect: Different companies Many/any devices Applications Different clients

Not just browsers

Distribution and integration of application logic Enable the programmable Web

Not just the purely interactive Web Web Services are loosely coupled

Page 13: Web Services

New paradigm for Internet development Deliver applications as services Richer, customer-driven experience Continuous delivery of value/bits Third-generation Internet

Web Services Overview What is a Web Service?

Page 14: Web Services

Web Services Overview Evolution of the Web

Generation 1

Static HTML

HTML

Generation 2

Web Applications

HTMLHTML, XML

HTML, XML

Generation 3

Web Services

Page 15: Web Services

Web Services Overview Benefits

Everyone Leverage existing infrastructure “Build or buy” development decisions Minimize development time/costs

Enterprises Integration imperative Dynamic, easy B2B relationships

New Web-based businesses Greater personalization New services/new revenue streams Be “everywhere” vs. single destination

Page 16: Web Services

Web Services Overview Possibilities

Scenario: Planning a trip Go to Expedia site (or Travelocity, or …) Log in. Find the flights you want

Don’t have to reenter seat/meal/airline/frequent flyer/… info System can find lowest price fare by looking at your calendar(s)

Purchase tickets w/o entering credit card # Flight info automatically added to your calendar and your

spouse’s calendar Book rental car/hotel w/your preferences; added to calendar On day of trip get notified of flight status via

email/toast/pager/cell phone

Page 17: Web Services

Other Web Services

Partner Web Service

Partner Web Service

Data Access and Storage Tier

Application Business Logic Tier

YourCompany.com

Internet + XML

Web Services Overview Application Model

Other Applications

End Users

Page 18: Web Services

Web Services Overview Sample Web Services

E-commerce: order books, office supplies, other products

Track packages: UPS, FedEx Weather Maps Telephone redirection, customizable rules

and messages

Page 19: Web Services

Agenda

Web Services Overview Underlying Technologies Developing a Web Service Consuming Web Services Miscellaneous .NET My Services

Page 20: Web Services

Underlying Technologies XML Is the Glue

Program the Web

XML

Browse the Web

HTML

TCP/IP

Connect the Web

Technology

Innovation

Connectivity PresentationConnecting ApplicationsFTP, E-mail, Gopher

Web Pages Web Services

Page 21: Web Services

Underlying Technologies Web Services Stack (Standards)

Ubiquitous Communications: Internet

Universal Data Format: XML

Wire Format: Service Interactions: SOAP

Description: Formal Service Descriptions: WSDL

Simple, Open, Broad Industry Support

Directory: Publish & Find Services: UDDI

Page 22: Web Services

Underlying Technologies Web Services Stack

Discovery Directory allows potential clients to locate relevant

Web Services UDDI

A Description language defines the format of methods provided by a Web Service WSDL

Page 23: Web Services

Underlying Technologies Web Services Stack

Directoryhttp://www.uddi.org

UDDI

WSDL

SOAP

Descriptionhttp://www.ibuyspy.com/ibuyspycs/InstantOrder.asmx?wsdl

Wire Format

Locate a Service

Link to Discovery Document (XML)

Return Service Description (XML)

Return Service Response (XML)

Request Service

Request Service Description

Web

Ser

vice

Clie

nt

UD

DI o

ro

ther

directo

ry service

Web

Service

Page 24: Web Services

Underlying TechnologiesWeb Service Wire Format

The Web Service Wire Format specifies how specific messages are exchanged HTTP-GET HTTP-POST SOAP

HTTP-GET and HTTP-POST use a minimal HTTP interface to invoke Web Services Limited support for data types

SOAP provides a robust HTTP/XML interface Extensive support for data types

Page 25: Web Services

XML is designed to represent and transfer structured data In HTML: <p>Jan 15, 2000 </p> In XML: <OrderDate>Jan 15, 2000</OrderDate>

XML does not display or transform data XML separates data from formatting and transforming HTML and XML are both derived from SGML

In different ways

XML OverviewXML Basics

Page 26: Web Services

XML is composed of tags and attributes Tags can be nested

Representing entities, entity properties, and entity hierarchy

<ROOT><Orders OrderID="10643" CustomerID="ALFKI" EmployeeID="6" OrderDate="1997-08-25T00:00:00" RequiredDate="1997-09-22T00:00:00" ShippedDate="1997-09-02T00:00:00" />

</ROOT>

XML OverviewXML Syntax

Page 27: Web Services

XML schemas describe the structure of an XML document XML schemas describe the tag and attribute

specifications Simple and compound data types

XML schemas also describe constraints on the contained text

XML schemas and the DTD are mutually exclusive

XML OverviewXML Schemas

Page 28: Web Services

A lightweight protocol for exchanging information in a distributed, heterogeneous environment It enables cross-platform interoperability

Interoperable OS, object model, programming language neutral Hardware independent Protocol independent

Works over existing Internet infrastructure

SOAP Overview

Page 29: Web Services

Guiding principle: “Invent no new technology” Builds on key Internet standards

SOAP ≈ HTTP + XML SOAP 1.2, W3C working draft Tutorial:

http://www.w3.org/TR/2002/WD-soap12-part0-20020626/

The SOAP specification defines: The SOAP message format How to send messages How to receive responses Data encoding

SOAP Overview

Page 30: Web Services

Objects-by-reference Message-oriented

Complicated Doesn’t try to solve every problem in distributed

computing Can be easily implemented

SOAP SOAP Is Not…

Page 31: Web Services

SOAPThe HTTP Aspect

SOAP requests are HTTP POST requests

POST /WebCalculator/Calculator.asmx HTTP/1.1Content-Type: text/xmlSOAPAction: “http://tempuri.org/Add”Content-Length: 386

<?xml version=“1.0”?><soap:Envelope ...> ...</soap:Envelope>

Page 32: Web Services

SOAP Message

SOAP Envelope

SOAP Header

SOAP Body

Message Name & Data

Headers

Headers

XML-encoded SOAP message name & data

<Body> contains SOAP message name

Individual headers

<Header> encloses headers

<Envelope> encloses payload

Protocol binding headers

The complete SOAP message

SOAPMessage Structure

Page 33: Web Services

SOAPSOAP Message Format

An XML document using the SOAP schema:<?xml version=“1.0”?><soap:Envelope ...> <soap:Header ...> ... </soap:Header> <soap:Body> <Add xmlns=“http://tempuri.org/”> <n1>12</n1> <n2>10</n2> </Add> </soap:Body></soap:Envelope>

Page 34: Web Services

SOAPServer Responses

Server replies with a “result” message:HTTP/1.1 200 OK...Content-Type:text/xmlContent-Length: 391

<?xml version=“1.0”?><soap:Envelope ...> <soap:Body> <AddResult xmlns=“http://tempuri.org/”> <result>28.6</result> </AddResult> </soap:Body></soap:Envelope>

Page 35: Web Services

SOAPEncoding Complex Data

Data structures are serialized as XML:

<soap:Envelope ...> <soap:Body> <GetStockDataResult xmlns=“http://tempuri.org/”> <result> <Description>Plastic Novelties Ltd</Description> <Price>129</Price> <Ticker>PLAS</Ticker> </result> </GetStockDataRseult> </soap:Body></soap:Envelope>

Page 36: Web Services

Builds on HTTP Security HTTPS

Developers / IT choose which methods to expose explicitly

Does not pass application code Firewall-friendly Type safe

SOAPSecurity and Features

Page 37: Web Services

Sun Microsystems DevelopMentor Inc. Digital Creations IONA Technologies PLC Jetform ObjectSpace Inc. Rockwell Software Inc. SAP Compaq

Microsoft Rogue Wave Software Inc. Scriptics Corp. Secret Labs AB UserLand Software Inc. Zveno Pty. Ltd. IBM Hewlett Packard Intel

SOAPIndustry Support

Page 38: Web Services

POST /StockQuote HTTP/1.1Host: www.stockquoteserver.comContent-Type: text/xml; charset="utf-8"Content-Length: nnnnSOAPAction: "Some-URI“

<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" SOAP-ENV: encodingStyle = "http://schemas.xmlsoap.org/soap/encoding/"> <SOAP-ENV:Body> <m:GetLastTradePrice xmlns:m="Some-URI"> <symbol>DIS</symbol> </m:GetLastTradePrice> </SOAP-ENV:Body></SOAP-ENV:Envelope>

SOAPExample of a SOAP Request

Page 39: Web Services

HTTP/1.1 200 OKContent-Type: text/xml; charset="utf-8"Content-Length: nnnn

<SOAP-ENV:Envelope xmlns:SOAP-ENV= "http://schemas.xmlsoap.org/soap/envelope/" SOAP-ENV: encodingStyle= "http://schemas.xmlsoap.org/soap/encoding/"/> <SOAP-ENV:Body> <m:GetLastTradePriceResponse xmlns:m="Some-URI"> <Price>34.5</Price> </m:GetLastTradePriceResponse> </SOAP-ENV:Body></SOAP-ENV:Envelope>

SOAPExample of a SOAP Response

Page 40: Web Services

HTTP/1.1 500 Internal Server ErrorContent-Type: text/xml; charset="utf-8"Content-Length: nnnn

<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"> <SOAP-ENV:Body> <SOAP-ENV:Fault> <faultcode> SOAP-ENV: MustUnderstand </faultcode> <faultstring>SOAP Must Understand Error </faultstring> </SOAP-ENV:Fault> </SOAP-ENV:Body></SOAP-ENV:Envelope>

SOAPExample of a SOAP Error

Page 41: Web Services

XML schema for describing Web Services1. Service interface definition

– Abstract semantics for Web Service

2. Service implementation definition– Concrete end points and network addresses where Web

Service can be invoked

Clear delineation between abstract and concrete messages

WSDLWeb Services Description Language

Page 42: Web Services

WSDLWSDL Schema

ImplementationInterface

<portType>

<message>

<import>

<definitions>

<binding>

<types>

<port>

<import>

<definitions>

<service>

Page 43: Web Services

WSDLWSDL Schema

Interface

<portType>

<message>

<import>

<definitions>

<binding>

<types>

• <definitions> are root node of WSDL

• <import> allows other entities for inclusion

• <types> are data definitions - xsd

• <message> defines parameters of a Web Service function

• <portType> defines input and output operations

• <binding> specifies how each message is sent over the wire

Page 44: Web Services

WSDLWSDL Schema

Implementation

<port>

<import>

<definitions>

<service>

• <service> specifies details about the implementation

• <port> contains the address itself

Page 45: Web Services

Open – allows for other namespaces and thus highly extensible

Ability to import other schemas & WSDL Provides “recipe” for Web Services Provides both interface and implementation

details Allows for separation of the two

WSDL WSDL Elements

Page 46: Web Services

WSDL Example

Demo: MyHello service on db.gsu.eduhttp://db.gsu.edu:8080/hello-jaxrpc/hello?WSDL

Page 47: Web Services

UDDIOverview

UDDI = Universal Description, Discovery, and Integration Industry Initiative to address discovery

A registration database for Web Services

Specifications Schema for service providers and descriptions API for publishing and searching Developed on industry standards (XML, HTTP, TCP/IP, SOAP) Applies to both XML and non-XML services

Implementation Public and private instances of specification

Page 48: Web Services

Marketplace

UDDIThe Vision

Search Portal

Marketplace

Search Portal

Marketplace

Business Users

Advanced Discovery via Portals and Marketplaces

UDDI Registries and Protocol

Technical Users

Page 49: Web Services

Resources

Web Services Essentialshttp://msdn.microsoft.com/library/default.asp?URL=/library/techart/webservicesessentials.htm

SOAPhttp://msdn.microsoft.com/soap

SOAP Specification http://www.w3.org/TR/SOAP/

Don Box on SOAP http://msdn.microsoft.com/msdnmag/issues/0300/soap/soap.asp

Introduction to SOAPhttp://www.w3.org/2000/xp/Group/Admin/minutes-oct1100/soap-xp-wg_files/frame.htm

Page 50: Web Services

Resources

WSDL Specificationhttp://www.w3.org/TR/wsdl

Sun Microsystems: http://java.sun.com/webservices IBM: http://www.ibm.com/webservices Microsoft: http://www.microsoft.com/webservices A Quick Introduction to WSDL

http://msdn.microsoft.com/library/default.asp?url=/library/enus/soap/htm/soap_overview_72b0.asp?frame=true

UDDIhttp://www.uddi.orghttp://uddi.microsoft.com

Page 51: Web Services

Resources

HailStormhttp://www.microsoft.com/net/hailstorm.asp

Building Web Services with SOAP and ASP.NEThttp://msdn.microsoft.com/msdnmag/issues/01/02/WebComp/webcomp.asp

GXA Web Services Specificationshttp://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnsrvspec/html/wsspecsover.asp?frame=true