| Oracle9iAS Containers for J2EE JSP Tag Libraries and Utilities Reference Release 2 (9.0.3) Part Number A97678-01 | 
 | 
Oracle furnishes a tag library with OC4J that enables developers to create JSP pages for use as client programs for Web services.
This chapter describes the tag library and is organized as follows:
This chapter is written with the assumption that you are already familiar with Web services, Simple Object Access Protocol (SOAP), and the Web Services Definition Language (WSDL); however, some overview is provided here. There are also references to additional documents, including related specifications from the World Wide Web Consortium (W3C).
The OC4J Web services tag library is based on Oracle9iAS Web Services. See the Oracle9iAS Web Services Developer's Guide for information.
This section provides a quick overview of Web services concepts, covering the following topics:
Web services are sets of procedures, or actions, that can be invoked by a client over the Internet. For example, there might be a "World Cup Soccer" service that consists of actions to get scores, schedules, and standings.
A Web service must have the following features:
For more information about Web services, particularly Oracle9iAS Web Services, you can refer to the Oracle9iAS Web Services Developer's Guide.
For related specifications, refer to the following Web sites:
http://www.w3.org/TR/SOAP (W3C SOAP specification)
http://www.w3.org/TR/wsdl (W3C WSDL specification)
http://www.uddi.org/specification.html (UDDI specification)
This section offers a brief overview of SOAP. See the W3C Simple Object Access Protocol (SOAP) 1.1 specification for details.
SOAP is a lightweight, XML-based protocol for exchanging typed and structured data over the Internet or other distributed environments. Among other features, SOAP supports remote procedure call (RPC) and message-oriented data exchanges.
In a message-oriented implementation, data is exchanged through a modular packaging and encoding model. A message is a WSDL component that specifies input data parts and output data parts associated with an operation. See "Overview of Web Service Messages and XML Schema Definitions" for more information.
RPC is an alternative to sockets, with the communication interface being at the level of procedure calls. It is as though you are calling a local procedure, but arguments of the call are actually packaged and sent to a remote target. The RPC mechanism uses a request/response methodology, where an end-point receives a procedure-oriented message and sends back a corresponding response.
Using SOAP with RPC is independent of the protocol binding. Where HTTP is the protocol binding, HTTP requests correspond to RPC calls, and HTTP responses correspond to RPC responses.
Key aspects of SOAP include the following:
A Web service is described using the XML-based Web Services Definition Language, in a WSDL (.wsdl) document. 
Here are some key WSDL terms:
To be more precise than previously, a Web service is really a collection of related ports, or end-points, not just a collection of abstract actions or operations.
The WSDL specification outlines the general structure of a WSDL document, which includes the following key elements. Refer to the W3C Web Services Description Language (WSDL) 1.1 specification for complete information.
<types>--This element , through one or more <schema> subelements, contains descriptions of the data that is exchanged in messages used by the operations of the service. 
<message>--A <message> element provides an abstract definition of data being sent as input or output for an operation.
<portType>--This element, through one or more <operation> subelements, contains abstract definitions of the operations of the Web service. An <operation> element specifies the message that is used for input and the message that is used for output for the operation.
<binding>--This element, also through <operation> subelements, binds each operation to the particular protocol and data formats to be used.
<service>--This element defines the ports, or end-points, of the Web service. Within the <service> element is one or more <port> subelements, where each <port> element ties a binding to an address to define the end-point.
Messages define parameters used by the operations, or methods, of a Web service. A message is a typed definition of the data being communicated, consisting of one or more parts. Each part corresponds to a logical entity, such as a "Purchase Order" part and an "Invoice" part. For each part, there are type specifications for the associated data items.
In a SOAP-based implementation, such as for Oracle9iAS Web Services, the data types used by a message are defined through the XML Schema Definition (XSD) language, which supports predefined simple types as well as user-defined complex types.
With an implementation that uses XSD, the syntax for defining a message is as follows:
<message name="nmtoken"> <part name="nmtoken" [type="qname"] [element="qname"] /> </message>
In this syntax, the element attribute refers to where an XSD complex type is defined using XSD syntax, the type attribute indicates an XSD simple type, "nmtoken" indicates a standard XML name token, and "qname" indicates a standard XML qualified name. There can be zero or more messages, and zero or more parts for each message.
For a SOAP encoding style of encoded, only simple types are allowed, so the element attribute is not used. For an encoding style of literal, you can have simple types or complex types, so a <part> element can use either the type attribute or the element attribute, but not both.
Here is an example of a message definition, from "Example: WSDL Definition":
<message name="GetLastTradePriceInput"> <part name="body" element="xsd1:TradePriceRequest"/> </message>
GetLastTradePriceInput is the name of the message, which is an input message (as the name implies). In this case, the element attribute refers to a namespace where a complex type, TradePriceRequest, is defined. Here is an example of such a definition (also part of "Example: WSDL Definition" below):
<element name="TradePriceRequest"> <complexType> <all> <element name="tickerSymbol" type="string"/> <element name="companyName" type="string"/> </all> </complexType> </element>
An XML schema primer is available from W3C at the following location:
http://www.w3.org/TR/xmlschema-0/
This example shows the WSDL definition of a Web service, and illustrates its input and output messages embedded in an HTTP request and HTTP response, respectively.
The W3C Web Services Description Language (WSDL) 1.1 specification provides the following example of a WSDL document, which defines a stock quote service that takes a ticker symbol as input and returns the current stock price as output. Note this uses a SOAP encoding style of literal, so complex types are allowed (and used).
<?xml version="1.0"?> <definitions name="StockQuote" targetNamespace="http://example.com/stockquote.wsdl" xmlns:tns="http://example.com/stockquote.wsdl" xmlns:xsd1="http://example.com/stockquote.xsd" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns="http://schemas.xmlsoap.org/wsdl/"> <types> <schema targetNamespace="http://example.com/stockquote.xsd" xmlns="http://www.w3.org/2000/10/XMLSchema"> <element name="TradePriceRequest"> <complexType> <all> <element name="tickerSymbol" type="string"/> </all> </complexType> </element> <element name="TradePrice"> <complexType> <all> <element name="price" type="float"/> </all> </complexType> </element> </schema> </types> <message name="GetLastTradePriceInput"> <part name="body" element="xsd1:TradePriceRequest"/> </message> <message name="GetLastTradePriceOutput"> <part name="body" element="xsd1:TradePrice"/> </message> <portType name="StockQuotePortType"> <operation name="GetLastTradePrice"> <input message="tns:GetLastTradePriceInput"/> <output message="tns:GetLastTradePriceOutput"/> </operation> </portType> <binding name="StockQuoteSoapBinding" type="tns:StockQuotePortType"> <soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/> <operation name="GetLastTradePrice"> <soap:operation soapAction="http://example.com/GetLastTradePrice"/> <input> <soap:body use="literal"/> </input> <output> <soap:body use="literal"/> </output> </operation> </binding> <service name="StockQuoteService"> <documentation>My first service</documentation> <port name="StockQuotePort" binding="tns:StockQuoteBinding"> <soap:address location="http://example.com/stockquote"/> </port> </service> </definitions>
This WSDL definition first specifies the GetLastTradePriceInput and GetLastTradePriceOutput input and output messages, next ties them to the operation GetLastTradePrice, then defines a binding and a port for that operation.
Corresponding to the Web service defined in the preceding example, this section shows what the messages would look like--the soap-enveloped input message embedded in an HTTP request, and the soap-enveloped output message embedded in an HTTP response. These examples are also from the W3C Web Services Description Language (WSDL) 1.1 specification.
Here is a request:
POST /StockQuote HTTP/1.1 Host: www.stockquoteserver.com Content-Type: text/xml; charset="utf-8" Content-Length: nnnn SOAPAction: "SOAP_URI" <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"> <soapenv:Body> <m:GetLastTradePrice xmlns:m="xmlns_URI"> <m:tickerSymbol>DIS</m:tickerSymbol> </m:GetLastTradePrice> </soapenv:Body> </soapenv:Envelope>
In this example, xmlns_URI is a URI to the location where the GetLastTradePrice operation and its messages are defined, such as the WSDL document in the preceding "Example: WSDL Definition". This is also where tickerSymbol is defined. The request is for a stock quote for Walt Disney Co. SOAP_URI is the URI for the SOAP action HTTP header for the HTTP binding of SOAP.
And here is the response:
HTTP/1.1 200 OK Content-Type: text/xml; charset="utf-8" Content-Length: nnnn <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"> <soapenv:Body> <m:GetLastTradePriceResponse xmlns:m="Some_URI"> <m:price>34.5</m:price> </m:GetLastTradePriceResponse> </soapenv:Body> </soapenv:Envelope>
By convention, the response for an operation Xxxx is called XxxxResponse.
This section provides an overview and details of the Web services tag library, as well as an overview of Oracle9iAS Web Services, upon which the tag library implementation is based. The section is organized as follows:
The Web services tag library provided with OC4J enables developers to conveniently create JSP pages for Web service client applications. The implementation uses a SOAP-based, RPC-style mechanism. A client application would access the WSDL document, and then use the WSDL information to access the operations of a Web service.
The tag library also uses the Oracle implementation of the dynamic invocation API, described in the Oracle9iAS Web Services Developer's Guide. When a client application acquires a WSDL document at runtime, the dynamic invocation API is the vehicle for invoking any SOAP operation described in the WSDL document. The tag handler uses the API in sending a SOAP request that invokes a Web service, and in handling the SOAP response.
The Oracle dynamic invocation API consists of classes and interfaces in the oracle.j2ee.ws.client and oracle.j2ee.ws.client.wsdl packages.
The oracle.j2ee.ws.client package includes the following:
WebServiceProxyFactory--Given a WSDL document (through a Java input stream that contains the document or through the URL of the document), a WebServiceProxyFactory instance can use the name of a service and the name of one of its ports, as specified in the WSDL document, to instantiate a WebServiceProxy class (a class that implements the WebServiceProxy interface).
WebServiceProxy--Use this interface in representing a service defined in a WSDL document. Each WebServiceProxy instance is based on the location of the WSDL document and, optionally, on additional qualifiers that identify which service and port should be used. A WebServiceProxy class exposes methods to determine the WSDL port type, including the syntax and signatures of all operations exposed by the WSDL document, and to invoke the defined operations.
WebServiceMethod--Use this interface in invoking a Web service method, or operation.
The oracle.j2ee.ws.client.wsdl package includes the following:
Operation--This interface represents a WSDL operation.
Message--This interface describes a message used in the input or output of an operation.
Part--This interface describes a message part.
Input--This interface represents an input message.
Output--This interface represents an output message.
This section provides an overview of the OC4J Web services tag library and its functionality. The tag library includes support for binding to a Web service, using a Web service operation through SOAP requests and SOAP responses, defining input and output message parts, mapping SOAP/XML data types to Java types, and setting custom properties for use by the client application.
The tag library supports invoking operations defined in WSDL documents that use the W3C XML schema version whose namespace is the following:
http://www.w3.org/2001/XMLSchema
The Web services tag library includes the webservice tag, optionally with nested map and property tags, and the invoke tag, optionally with nested part tags. They are used as follows.
webservice--Use this tag to create a Web service proxy. The tag requires the URL of a WSDL document and then uses one of the following combinations:
map--The Web service proxy uses this tag, if specified, to add an entry to the SOAP mapping registry, which is a registry that maps local SOAP/XML types to Java types. Any number of map tags can be nested within a webservice tag, one tag for each desired type mapping.
property--Optionally, use this tag to define any of several supported custom properties for use by the Web service client application. Each property tag must be nested within the webservice tag, and the property will have the same scope as the parent Web service.
invoke--Use this tag to invoke an operation of the Web service. An invoke tag accesses a Web service proxy either by being nested within a webservice tag, or through a scripting variable.
part--Use this tag if the operation has input message parts, one part tag for each input part. 
  
 
This section supplies detailed descriptions of the OC4J Web services tags, including syntax documentation:
The Web services tag library, a standards-compliant JavaServer Pages tag library implementation, is included in the ojsputil.jar file, which is provided with OC4J. Verify that this file is installed and in your classpath.
To use the Web services tag library, the tag library descriptor file, wstaglib.tld, must be deployed with the application, and any JSP page using the library must have an appropriate taglib directive. In an Oracle9iAS installation, the TLD file is in the "well-known" tag library directory. Refer to the Oracle9iAS Containers for J2EE Support for JavaServer Pages Developer's Guide for information about taglib directives and the well-known tag library directory.
For an example that uses the tags described in this section, see "Web Services Tag Examples".
| Notes: 
 
 | 
Use this tag to create a Web service proxy--an instance of a class that implements the oracle.j2ee.ws.client.WebServiceProxy interface. The tag requires the URL of a WSDL document and uses a binding and SOAP location or a service name and port, as follows:
Using a binding and SOAP location is particularly useful for a Web service whose WSDL document is accessed through a UDDI registry. In that case, the binding and location can be determined through UDDI queries and supplied to the tag through request-time expressions.
After the Web service proxy is created, it will use any nested map tags to add entries to the SOAP mapping registry. See the next section, "Web Services map Tag".
<ws:webservice wsdlUrl = "WSDL_URL_of_Web_service" [ id = "variable_name_for_Web_service_proxy" ] [ scope = "page" | "request" | "session" | "application" ] [ binding = "SOAP_binding_information" ] [ soapLocation = "SOAP_endpoint_URL" ] [ service = "service_name_in_WSDL" ] [ port = "port_name_for_service" ] ...body / nested tags... </ws:webservice>
wsdlUrl (required)--Use this attribute to specify a URL where the WSDL for the desired Web service can be accessed.
id--If the Web service is to be accessed by an invoke tag that is not nested within the webservice tag, use the id attribute to specify the name for a WebServiceProxy scripting variable so that the variable can be referenced by the invoke tag. The specified name must be a valid Java identifier. When you use the id attribute, the specified variable will be declared automatically with scope AT_END (available from the webservice end-tag to the end of the JSP page).
scope--Optionally, specify the scope of the webservice tag. The default setting is "page".
binding--In scenario #1 above, use the binding attribute to specify the SOAP binding information for a SOAP location (end-point URL) that you specify through the soapLocation attribute. You must use these attributes together. The binding information is as defined in the WSDL document, specifying concrete protocol and data format specifications for the operations and messages defined by a particular port type.
soapLocation--In scenario #1 above, use soapLocation to specify a SOAP location (end-point URL), as defined in the WSDL document, for which the binding information specified through the binding attribute applies. You must use these attributes together.
service--In scenario #2a above, use the service attribute to specify the name of a service defined in the WSDL document. You must use this attribute with the port attribute, but both are ignored if you use binding and soapLocation.
port--In scenario #2a above, use the port attribute to specify a port for the service that is specified through the service attribute. You must use these attributes together. The Web service proxy will use the specified port. The port address will be as specified in the corresponding <service> element in the WSDL document. The service and port attributes are ignored if you use binding and soapLocation.
For interoperability, a mapping mechanism is necessary to map WSDL-defined SOAP/XML data types to the Java types used in JSP pages of a Java client application. This is possible through the Oracle9iAS Web Services SOAP mapping registry.
You can have any number of map tags nested within a webservice tag, to have the Web service proxy add entries to the registry. Use one map tag for each desired type mapping.
The registry is an instance of the XMLJavaMappingRegistry class of the org.apache.soap.util.xml package. A WebServiceProxy instance has a getXMLMappingRegistry() method to access the registry.
The map tag includes attributes to specify the encoding style, serializer, deserializer, and namespace URI to facilitate the type mapping. The Web services tag library supports custom serializers and deserializers, if you want to create your own.
<ws:map localName = "local_name_of_SOAPXML_type" namespaceUri = "URI_of_namespace_for_SOAPXML_type" javaType = "Java_type_to_map" encodingStyle = "URL_of_SOAP_encoding_style" java2xmlClassName = "Java_to_XML_serializer" xml2javaClassName = "XML_to_Java_deserializer" />
localName (required)--Specify the local name of the SOAP/XML data type, such as SOAPStruct, for example.
namespaceUri (required)--Specify a valid URI for the namespace of the SOAP/XML data type. The following is an example:
http://soapinterop.org/xsd
javaType (required)--Specify the Java type which you want to map to the SOAP/XML type. The types must be legally mappable.
encodingStyle (required)--Specify a valid URL for a SOAP encoding style. The following is an example:
http://schemas.xmlsoap.org/soap/encoding
java2xmlClassName (required)--Specify the class name with the functionality for serializing the data for Java-to-XML conversion. This can be a custom class. The following is an example:
org.apache.soap.encoding.soapenc.BeanSerializer
xml2javaClassName (required)--Specify the class name with the functionality for deserializing the data for XML-to-Java conversion. This can be a custom class. The following is an example:
org.apache.soap.encoding.soapenc.BeanSerializer
You can optionally use this tag to specify a name/value pair that defines any of several supported custom properties for use by the Web service client application. For example, you could use property tags to specify an HTTP proxy host and proxy port if a proxy is required for access through a network firewall. The following properties are supported:
http.proxyHost--Use this property to specify the host name of an HTTP proxy server.
http.proxyPort--Use this property to specify a port number of an HTTP proxy server.
javax.net.ssl.KeyStore--Use this property to specify the full path of an Oracle security wallet file. 
<ws:property name="http.proxyHost" | "http.proxyPort" | "javax.net.ssl.KeyStore" value = "property_value" />
property (required)--Specify the property you want to set; it must be one of the supported properties listed in the tag syntax.
value (required)--Specify the desired value of the property (a host name, port number, or full path to an Oracle wallet file).
Use this tag to invoke an operation of the Web service. The tag handler will call the remote Web service operation by passing an input message in a SOAP request, then will wait for the SOAP response. You must specify the operation, and an object ID for the object that will contain the returned response. The tag handler uses the operation name to find the operation in the WSDL document.
The invoke tag gains access to a Web service proxy in one of two ways:
invoke tag is nested within the webservice tag that establishes the proxy.
invoke tag uses its webservice attribute to access a WebProxyService scripting variable created through a webservice tag id attribute.
In a situation where there are overloaded operations--two operations of the same name using different I/O messages--the invoke tag has attributes to specify the input and output message names for the desired operation. In this case, the specified input and output message names are used to form the RPC signature of the operation. Otherwise, the RPC signature is the default according to the WSDL document.
If the output message has multiple parts, then the returned result is an array of message parts (all within a single SOAP response).
<ws:invoke id = "variable_name_for_output_result" operation = "operation_to_invoke" [ webservice = "variable_name_of_Web_service_proxy" ] [ inputMsgName = "name_of_input_message" ] [ outputMsgName = "name_of_output_message" ] ...body / nested tags... </ws:invoke>
id (required)--Specify a scripting variable name for the output result object. The specified name must be a valid Java identifier. The variable will be declared automatically with scope AT_END (available from the invoke end-tag to the end of the JSP page).
operation (required)--Specify an operation to be executed (an operation from the WSDL document).
webservice--Use this attribute if you want to specify the name of a WebServiceProxy scripting variable corresponding to the service to invoke. This is not necessary if the invoke tag is nested inside the webservice tag that accesses the desired service.
inputMsgName--Optionally specify the input message name--the name of a wsdl:input tag in the WSDL document--for the operation. This is only necessary if there are overloaded operations (operations with the same name that use different message names).
outputMsgName--Optionally specify the output message name--the name of a wsdl:output tag in the WSDL document--for the operation. This is necessary only if there are overloaded operations (operations with the same name that use different message names).
Use this tag if the operation being performed requires input message part values, using one part tag for each input part.
<ws:part name = "part_name" value = "part_value" />
name (required)--Specify the name of the input part (a valid Java identifier).
value (required)--Specify the value of the input part.
This section provides two examples--a template for use of the tag library, and a concrete JSP page example.
<HTML> <HEAD> <TITLE>Title</TITLE> </HEAD> <BODY> <H2>This is sample HTML text.</H2> <%@ taglib uri="http://xmlns.oracle.com/j2ee/jsp/tld/ws/WsTagLibrary.tld" prefix="ws" %> <ws:webservice id="myws" wsdlUrl="wsdlurl" { binding="" soapLocation="" | service="" port="" } { scope="page | request | session | application" } > <ws:property name="property" value="string"/> <ws:map encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" localname="SOAPStruct" namespaceUri="http://soapinterop.org/xsd" javaType="MySoapStructBean" java2xmlClassName="org.apache.soap.encoding.soapenc.BeanSerializer" xml2javaClassName="org.apache.soap.encoding.soapenc.BeanSerializer" /> </ws:webservice> <ws:invoke id="result" webservice="myws" operation="add" inputMsgName="" outputMsgName=""> <ws:part name="part_name" value="{string | <%= expression %>}"/> </ws:invoke> <% =result %> </BODY> </HTML>
<%@ page contentType="text/html"%> <%@ taglib uri="http://xmlns.oracle.com/j2ee/jsp/tld/ws/wstaglib.tld" prefix="ws" %> <HTML> <HEAD> <META HTTP-EQUIV="Content-Type" CONTENT="text/html; "> </HEAD> <BODY> <% String itemID = request.getParameter("itemID"); %> <ws:webservice id="ebay" wsdlUrl="http://www.xmethods.net/sd/2001/EBayWatcherService.wsdl" binding="eBayWatcherBinding" soapLocation="http://services.xmethods.net:80/soap/servlet/rpcrouter" scope="page"> <ws:property name="http.proxyHost" value="www-proxy.us.oracle.com"/> <ws:property name="http.proxyPort" value="80"/> </ws:webservice> <ws:invoke id="price" webservice="ebay" operation="getCurrentPrice"> <ws:part name="auction_id" value="<%=itemID%>"/> </ws:invoke> <B> Action price for eBay Item # <%=itemID%> is : </B> <P> $<%= price%> @ <%= new java.util.Date()%> </P> </BODY> </HTML>
| 
 |  Copyright © 2002 Oracle Corporation. All Rights Reserved. | 
 |