Download presentation
Presentation is loading. Please wait.
Published byCamilla Harmon Modified over 9 years ago
1
A Semantic-Based Web Service Composition Facility for ebXML Registries Asuman Dogac Yildiray Kabak Gokce Laleci Middle East Technical University Ankara Turkey
2
Outline Web Services, WSDL, SOAP Why WSDL is not enough? Semantic of Web Services ebXML and the ebXML Registry Information Model How to Exploit Web Services Semantics through ebXML? A Web Service Composition Tool Conclusions
3
Web Services, WSDL, SOAP
4
Web Services Web services encapsulate business functions Check credit card number Payment processing Stock quotes Request for quote, bid processes They can be used to compose business processes Travel planning Health care …
5
What is a Web Service? A Web Service is an interface that describes: a collection of operations that are network-accessible through standardized XML messaging To put it simply, Web services are applications that interact with each other using Web standards Web Service Client Application XML WEB
6
Web Services Web Service Client Application XML WEB Existing Application Existing Application Existing applications can be wrapped as Web services Client and Service can use different platforms and programming languages Services can be composed to make composite services
7
Web Service Model Service Registry (ebXML or UDDI) - Web service descriptions Service Consumer Service Provider - Web service - Service Description in WSDL Publish service Discover service Invoke service through SOAP
8
Why WSDL is not enough?
9
Web Service Description Web ServiceService Consumer Web Service Description defines uses
10
WSDL Structure Service Port (e.g. http://host/service) Binding (e.g. SOAP, JMS, direct call) Abstract interface portType operation(s) inMesageoutMessage Port Binding Where to access it How to access it Abstract definition of the service (set of Operations) Operation: An Exchange of Messages between a service Requestor and a Service provider
11
XML Messaging: SOAP The current standard for XML Messaging is Simple Object Access protocol (SOAP) Applications typically communicate with Web services via SOAP messaging Typically HTTP is used as RPC transport XML is used as RPC encoding scheme
12
SOAP over HTTP HTTP POST Message SOAP Endpoint Reference XML Message SOAP Payload SOAP Header SOAP Body SOAP Envelope
13
The SOAP Envelope <SOAP-ENV:Envelope xmlns="http://schemas.xmlsoap.org/soap/envelope/">.........
14
SOAP Endpoint Reference 144.122.230.1680/ProductCatalog#getPrice IP Host AddressTCP Port No Object Endpoint ID POST /ProductCatalog HTTP/1.0 Host: http://www.srdc.metu.edu.tr Content-Type: text/xml; charset="utf-8" Content-Length: 500 SOAPAction: ``http://www.srdc.metu.edu.tr/ProductCatalog#getPrice"
15
SOAP Envelope <SOAP-ENV:Envelope xmlns:SOAP-ENV=" http://schemas.xmlsoap.org/soap/envelope/" SOAP-ENV:encodingStyle=" http://schemas.xmlsoap.org/soap/encoding" xmlns:xsi="http://www.w3.org/1999/XMLSchema-instance" xmlns:xsd="http://www.w3.org/1999/XMLSchema">
16
SOAP Body Palm Pilot Method Name Input Parameter
17
SOAP Response HTTP/1.0 200 OK Content-Type: text/xml; charset="utf-8" Content-Length: 400 <SOAP-ENV:Envelope xmlns:SOAP-ENV=" http://schemas.xmlsoap.org/soap/envelope/" SOAP-ENV:encodingStyle=" http://schemas.xmlsoap.org/soap/encoding" xmlns:xsi="http://www.w3.org/1999/XMLSchema-instance" xmlns:xsd="http://www.w3.org/1999/XMLSchema"> 2000. Standard Suffix
18
Web Service Semantics
19
Like their real-life counter parts, Web services have properties In order to exploit services in their full potential their properties must be defined: The methods of charging and payment The channels by which the service is requested and provided Constraints on temporal and spatial aspects Availability Service quality Security, trust and rights attached to a service
20
An Example Ontology for Travel Domain TravelService Entertainment Service Accommodation Service ReserveAFlightBuyATicket AirTransportation Transportation Service originatingFrom destinationTopaymentMethod Properties of the Generic Service Class
21
WSDL does not describe Web service semantics Web ServiceService Consumer Web Service Description defines Semantic description of the properties of a service uses
22
Taxonomies are not enough to define service semantics: An Example Taxonomy: UNSPSC 43.00.00.00.00 Communications and Computer Equipment and Peripherals and Components and Supplies 43.16.17.00.00 Business Transaction and Personal Business Software 43.16.17.02.00 Tax Preparation Software
23
ebXML
24
Electronic Business XML (ebXML) Electronic Business XML is an initiative from OASIS and United Nations Centre for Trade Facilitation and Electronic Business ebXML aims to provide the exchange of electronic business data in Business-to-Business and Business-to-Customer environments The ebXML specifications provide a framework in which EDI's substantial investments in Business Processes can be preserved in an architecture that exploits XML's technical capabilities
25
ebXML A joint global initiative by UN/ CEFACT – United Nations Center For Trade Facilitation And Electronic Business OASIS – Organization for the Advancement of Structured Information Standards United Nations Center for Trade Facilitation and Electronic Business Sets worldwide policy and technical development in trade facilitation and electronic business Developed international EDI standard, UN/ EDIFACT The initiative leverages from the success of EDI in large businesses, and intends reaching small and medium enterprises
26
ebXML Architecture’s functional components Business Process Specification Schema (BPSS) Business processes are not fixed! Trading Partner Information Collaboration Protocol Profile CPP Trading Partner Agreement Collaboration Protocol Agreement CPA Registry/Repository Messaging Service Core Components
27
An Overview of Functional Components in ebXML Repository ebXML Business Process Specifications Business Document Specification ebXML Core Components CPP CPA Business Service Interface Business Service Interface ContextFor ReferenceTo BuiltWith Implement one Partner Role Implement other Partner Role
28
ebXML Registry 3 Register Company Information 1 Request Business Details 4 Query about Company A Company B 5 Download Scenarios and Profiles 2 Build Local System 6 Agree on Business Arrangements 7 Do Business Transactions! ebXML compliant system
29
ebXML Registry Information Model (RIM) RegistryObject ClassificationNodeClassification RegistryPackageExtrinsicObjectService AssociationRegistryEntry ClassificationScheme
30
How to Exploit Web Services Semantics through ebXML?
31
Exploiting semantics In relating the semantics with the services advertised in service registries, there are two key issues: Where to store the generic semantics of the services How to relate the services advertised in the registry with the semantic defined through an ontology ReserveAFlight originatingFrom destinationTopaymentMethod MyService TravelService Entertainment Service Accommodation Service ReserveAFlight BuyATicket AirTransportation Transportation Service originatingFrom destinationTopaymentMethod ? ?
32
Where to store the generic semantics of the services? An ebXML registry allows to define semantics basically through two mechanisms: It allows properties of registry objects to be defined through “slots” and, Metadata can be stored in the registry through a “classification” mechanism
33
Relating a Web service Advertised with Service Ontology ReserveAFlight originatingFrom destinationTopaymentMethod MyService How to relate MyService to a generic service class?
34
Relating a Web service Advertised with Service Ontology in ebXML MyService: Registry Entry ReserveAFlight: ClassificationNode ServiceToIndustryClassification: Classification classsifiedObject classificationNode
35
How to relate services advertised with the generic ontology classes? By relating a service advertised with a node in classification hierarchy, we make the service an explicit member of this node The service also inherits the well-defined meaning associated with this node as well as the generic properties defined for this node When we associate “MyService” with “ReserveAFlightService”, its meaning becomes clear; that this service is a flight reservation service Assuming that the “ReserveAFlightService” service has the generic properties such as “originatingFrom”, “destinationTo” and “paymentMethod”, “MyService” also inherits these properties
36
“SubmitObjectRequest” which declares the semantic of “MyReserveAFlightService” and relates it with the “ReserveAFlightService” …
37
An Example “SubmitObjectRequest” (Cont’d) Istanbul New York Credit Card
38
An Example “SubmitObjectRequest” (Cont’d)
39
Service Composition: Travel Service Example
41
An AdhocQueryRequest to return “ReserveAFlightService” as a composite object including the slots <AdhocQueryRequest xmlns = "urn:oasis:names:tc:ebxml- regrep:query:xsd:2.0" xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation = "urn:oasis:names:tc:ebxml-regrep:query:xsd:2.0 query.xsd"> ReserveAFlightService
42
User Interface
43
A Filter Query Retrieving all the services classified by ReserveAFlightService Node and Originating from Istanbul ReserveAFlightService originatingFrom Istanbul …
44
Implementation Status A proof of concept implementation of the system is realized by using OASIS ebXML Registry Reference Implementation As an application server to host Web services to be accessed through SOAP, Apache Tomcat 4.1 is used The WSDL descriptions of the implemented services are generated through IBM Web services Toolkit 3.2 (WSTK) Finally IBM Web Services Invocation Framework 1.0 (WSIF) is used to invoke services.
45
Conclusions Web Services will transform the web from a collection of information into a distributed device of computation In order to employ their full potential, appropriate semantic mechanisms for web services need to be developed A semantic-based service composition tool for ebXML registries is described Service discovery and composition by using the semantics of services has been addressed in the literature where the weight of the work has been on using AI techniques to match the inputs and outputs of services requested and advertised The main problem with these approaches is the performance, which is not yet at the levels to be adopted by the industry
46
Conclusions In contrast to such approaches, we take a data management approach for service discovery by exploiting the meta data and the query mechanism of the ebXML registry With the tools we have provided, the registry is queried for explicit members of a classification node to obtain the generic parameters of the service and users are allowed to fill these in through graphical user interfaces generated dynamically Then the registry is queried for matching services; the corresponding WSDL files are obtained and through a workflow mechanism presented, the users can compose the discovered services The current workflow mechanism implemented is a simple one realizing basic workflow functionality As a future work, we plan to use one of the recent Web services choreography languages, such as BPEL4WS in composing the services
47
Thank you for your attention!
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.