web service service registry service requestor service provider publishfind bind

Post on 30-Mar-2015

220 Views

Category:

Documents

1 Downloads

Preview:

Click to see full reader

TRANSCRIPT

Web Service

Service Registry

Service Requestor

Service provider

Publish find

Bind

http://www.ibm.com/services/uddihttp://www.ibm.com/services/uddi/testregistryhttp://uddi.microsoft.comhttp://test.uddi.mirosoft.comhp – available soon

SOAP on HTTP

All the Service describe by UDDI

UDDI (xml schemas)UDDI- Universal Description, Discovery, and Integration

• Programmatic descriptions of businesses and the services supported

• Programmatic descriptions of web service specifications

• Programming model & schema

UDDI Business RegistryBusinesses register public information about themselves

White pages

Yellow pages

Green pages

Business name, Text description, Contact info, Known identifiers

Business categories (standard taxonomies)

Specify how to bind to a service provider. Technical info about service (how to invoke their services) – a point to WSDL

UDDI by examples

Two examples in UDDI registry http://uddi.microsoft.com

1. Flower (a regular service)

2. Xmethods (provides more than one web services, each one is described in a WSDL file)

WSDL- Web Service Description Language (an xml vocabulary that is used to define the service interface for a web service)

• Service interface detail• Access protocol • Contact endpoint (http://www.xmethods.net/detail.html?id=5 )

WSDL

Service Implementation Definition

Service

Port

Service Interface Definition

Binding

Message

PortType

Type

url to accept the soap request

WSDL ExamplesExamples from www.xmethods.net

Service Name: Joke of the DayDescription: Provides a random joke on each execution.WSDL URL:http://services.xmltoday.com/vx_engine/wsdl_publish.vep/joke.wsdl

Service Name: Sun/Moon rise and set data

Description: Sunrise, sunset, moonrise, moonset for a given latitude, longitude, date and time bias.WSDL URL:

http://www.armyaviator.com/cgi-bin/astro.exe/wsdl/IAstro

SOAPSimple Object Access Protocol (SOAP) is a lightweight protocol that defines a uniform way of passing XML-encoded data. (It also defines a way to perform remote procedure using HTTP as the underlying communication protocol)

soap messagehttp headers

soap Envelope

soap header

soap body

SOAPHeader• Use for authentication, transaction

management, payment, encryption etc.

Body• Special defines one body entry: Fault

<SOAP-ENV: Fault>

<faultcode>SOAP-ENV:server</faultcode>

<faultstring>Method’s getXXX is not supported.</ faultstring>

<faultactor>/xxx/xxx.jsp</ faultactor>/

</SOAP-ENV: Fault>

SOAP MessagePOST /WeatherServioce HTTP/1.1Host:www.weatherservice.comContent-Type: text/xml; charset=“utf-8”Content-Length: nnnnSOAPAction: “Some-URL”

<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:GetWeather xmlns:m=‘Some-URL’> <city>Seattle</city> <state>WA</state> </m:GetWeather> </SOAP-ENV:Body></SOAP-ENV:Envelope>

Web Services Stack

Service Negotiation

internet

Transport

Messaging

Service Description

Workflow, Choreography

Routing & Attachments

Managem

ent

Quality of S

ervice (QoS

)

Security

Web Service

• Currently most service entry (>95%) in UDDI registry are not web based service.

• In the future there will be private vertical UDDI registries and only trust company can register the service.

• Real business will used private UDDI registry to find the service.

Web Service

Service Registry

Service Requestor

Service provider

1. Service provider Publish Service2. Service requestor

find the service

3. Use the service through a SOAP call (use WSDL to build the SOAP request)

SOAP on HTTP

J2EE vs. .NetTo develop web service:java:

Platform > JVM > servlet, jsp, jdbc, jndi, jms, rmi, corba, EJB, jax package etc.

.net Wintel > CLR (common Language Runtime) > System.WebService, ASP.NET, DirectoryServices, System.Messaging, System.Runtime.Remoting, MSXML, SOAP, WSDL etc.

Tools availableTools for Java & Web Service• SOAP4J (apache & IBM), JAX package (sun)

• GLUE (the mind electric)

• Sun: bowstreet (include Jbuilder) • IBM websphere (include Application developer IDE)

Utility tools • Tcp monitor/tunnel (Soap4J) (to monitor soap message)

• Struts(apache) (to generate web interface from WSDL file)

Sun ONE (Open Net Environment)

SOAP4J (apache)• Client library to invoke SOAP service

- API for invoking SOAP RPC service- API for sending and receiving SOAP messages.

• Used as a server – side tool to implement SOAP accessible services.- RPC accessible service- Message accessible service

JAX package – Java API for XML

• JAXP – parse XML documents• JAXB – map XML elements to java classes• JAXM – sends SOAP messages• JAXR –provides a standard way to access

business registry• JAX-RPC – sends SOAP calls to remote

parties• MultiSchema Validation – not in JAX package

IBM/Apache Struts

Input Form JSP

Struts Controller

Servlet

WSDL Parser Action

WSDL

Output Form JSP

Struts Controller

Servlet

SOAP call Action

SOAP

GLUEto create software building blocks that are language, platform and location independent.

Useful feature:• A toolkit for parsing and manipulating XML• XML/Java mapping system• XML storage system• SSL authentication• A browser-based management console

Glue - Demopublic class Exchange { public float getRate( String country1, String country2 ) { return 122.69F; // always return a constant for this demo } }

import electric.registry.Registry;import electric.server.http.HTTP;public class Publish1 { public static void main( String[] args ) throws Exception { // start a web server on port 8004, accept messages via /glue HTTP.startup( "http://localhost:8004/glue" ); // publish an instance of Exchange Registry.publish( "urn:exchange", new Exchange() ); } }>java Publish1GLUE 1.2 © 2001 The Mind ElectricStartup server on http://129.57.41.138:8004/glue

Glue - Demohttp://einstein.jlab.org:8004/glue/urn:exchange.wsdl

Glue - Demoimport electric.registry.Registry;import examples.publish.IExchange;

public class Invoke1{ public static void main( String[] args ) throws Exception { // bind to web service whose WSDL is at the specified URL String url = "http://localhost:8004/glue/urn:exchange.wsdl"; Exchange exchange = (Exchange) Registry.bind( url, Exchange.class ); // invoke the web service as if it was a local java object float rate = exchange.getRate( "usa", "japan" ); System.out.println( "usa/japan exchange rate = " + rate ); } }

> java Invoke1 usa/japan exchange rate = 122.69

Glue - Demohttp://einstein.jlab.org:8080/console/index.espWSDL = http://einstein.jlab.org:8004/glue/urn:exchange.wsdl

IBM WebSphere Studio• WebSphere Stuio Site Developer – a tool for

developing and managing web sites that include HTML, JSP pages, Java servlets, rich media, xml, and web services.

• WebSphere Stuio Application Developer – a J2EE-compliant server-side Java tool, focusing on EJB development, deployment, and profiling, that also contains all the functionally of Site Developer.

IBM Application Developer• EJB and servlet creation and deployment• Performance profiling and analysis tools• Database wizards• Web services wizards• JSP tags• Team environment• XML tools• Core Java IDE• Web page wizards with dynamic effects• Java development environment

Web service development• Discover – browse the UDDI registry to locate existing Web

services for integration

• Create or transform – create Web service from existing projects.

• Build – wrap existing artifacts as SOAP and HTTP service and describe them in WSDL.

• Deploy – deploy the Web service into Websphere Application server or Tomcat.

• Test – test the web service as it runs locally or remotely

• Develop – generate a sample application to assist you in creating your own Web service client application.

• Publish – publish Web service to the UDDI business registry.

XML tools• Create, view, and validate DTDs and XML schemas• Create XML documents from DTD• Generate JavaBeans from DTD or xml schema• Define mappings between XML documents and

generate XSLT scripts that transform documents.• XSL stylesheet processor (xalan)

Sun - bowstreetBowStreet - Business Web Portal Solution• Portal Configuration & Customization

- Create portals within minutes using wizards.

- Build in portal “factory”

• Application Integration- Packaged application- Content & document management- Application servers- Messaging systems- XML, EJB, SOAP etc.

SummaryJAX package - use it in grid project to send soap

message

Apache SOAP4J - slow, include server and client.

GLUE – use it to generate WSDL and web console.

Sun: bowstreet (include Jbuilder) - no experience

IBM Websphere - only got complimentary preview copy - contains too much (most are not needed)

Jbuilder – Good IDE for java development

JLab Grid Web ServiceService:• Convert the GridServer (application) to a bean-like

application.• Modify GridService (servlet) to take SOAP request

using jaxm package (or other).• Add WSDL to describe our service (use GLUE or

other package to generate it).

Client:• Add Soap layer for requesting the service.• Create service web interface (html) using GLUE or

Struts package.

top related