ftp: connect: Connection timed out
SQL*Loader-704: Internal error: ulconnect: OCIServerAttach [0]
ORA-12154: TNS:could not resolve the connect identifier specified
Solution:- Please check your TNS details and SID
Labels
- Apache (10)
- Articles (4)
- BPM Tools (5)
- Glassfish (16)
- Hadoop (10)
- HP ALM (6)
- HP SOA Systinet (14)
- Issues (19)
- JAVA (85)
- JBoss (16)
- jQuery (4)
- Load Runner (37)
- Quality Center (49)
- Testing (24)
- Tips and Tricks (16)
- Tomcat (4)
- Usefull Links (18)
- Weblogic (41)
- WebSphere (2)
Wednesday, October 23, 2013
Sunday, October 6, 2013
Java Web Services
Java Web Services:
a. Web Service Architecture :
Now we will see about the elements of SOAP Messaging :
Ex:
What
is a web service?
A web service is a service which is available over
internet use a standardized xml messaging system and is not tied to any
operating system.
Main
purpose of web service:
The business logic can be written once it can be
accessed from various User Interface of different operating systems and
different devices. Such as Mobile, Computers, etc.
Main
Component of Web service :(XML)
The main advantage that a web service provides by
means of XML.XML can be accessed and viewed from different Interface without
worrying about platform or operating system.
Ex: A web service written in Java can be accessed by
a .Net or Perl Client by XML (request & response) vice versa.
In Java they are variety of ways from which we can create,
deploy and access web service.
We will be seeing the below concepts:
I. Basics of
Web service:
a. Web
Service Architecture
b. Basic
flow of Web service
c. SOAP
d. WSDL
e. UDDI
II. Java way of handling web services:
a. JAX-WS ( Java web service API)
b. JAX-RPC
(Java remote procedure call)
c. JAXP
(Java Parsing API)
d. JAXM
(Java Messaging API)
e. JAXB
(Java XML Binding API)
f. JAXR
(Java Metadata Registry API)
g. JAX-RS
(Java Restful Services)
They Beginning part would be more concept wise it would
be boring but it is important to understand these terminologies.
a. Web Service Architecture :
They are two ways to examine the Web
Service Architecture they are:
-
Examining individual role of a each webservie
actor
-
Web Service protocol stack
Roles of Web service :
It has three
components :
Service
provider
This is the provider
of the web service. The service provider implements the service
and makes it
available on the Internet.
Service
requestor
This is any consumer
of the web service. The requestor utilizes an existing web
service by opening a
network connection and sending an XML request.
Service
registry
This is a logically
centralized directory of services. The registry provides a central
place where
developers can publish new services or find existing ones. It therefore
serves as a
centralized clearinghouse for companies and their services.
Web Service protocol stack :
They web service protocol stack is still evolving .
It has four main layers
Service Transport :
This layer is responsible for the transporting of
Message between Applications currently have HTTP,SMTP,FTP,BEEP.
XML Messaging :
Responsible for encoding message in a common xml
format that message can be understood by either end .includes XML-RPC and SOAP.
Service
description
This layer is
responsible for describing the public interface to a specific web service.
Currently, service
description is handled via the Web Service Description Language
(WSDL).
Service
discovery
This layer is
responsible for centralizing services into a common registry, and
providing easy
publish/find functionality. Currently, service discovery is handled
via Universal
Description, Discovery, and Integration (UDDI).
As web services
evolve, additional layers may be added, and additional technologies may
be added to each layer.
b. Basic
flow of Web service :
To understand the basic flow we must know this term
SOAP,
WSDL, UDDI [We will see in detail about these in later part as for know we will
see what is what]
SOAP
:
Simple Object Access protocol .It is a XML based protocol for exchanging
information .It can be used along with variety of protocol such as HTTP,FTP etc along with various
operating system.
Given below is
the simple request & response obtain from a web service created by
JAX-WS technique in java. We will cover in detail about JAX-WS in later part.
package test;
import java.util.InputMismatchException;
import javax.jws.WebMethod;
import javax.jws.WebParam;
import javax.jws.WebService;
@WebService()
public class ss {
@WebMethod(operationName = "hello")
public
String hello(@WebParam(name = "input") // Method name hello accept a String Paramter
String
input) {
return
input;
}
}
After deploying this business method .We checks the
request and response.
EX
: SOAP REQUEST
<?xml version="1.0"
encoding="UTF-8"?>
<soap:Envelope
xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<ns0:hello xmlns:ns0="http://test/">
<input>Hello World</input>
</ns0:hello>
</soap:Body>
</soap:Envelope>
EX:
SOAP RESPONSE
<?xml version="1.0"
encoding="UTF-8"?>
<soap:Envelope
xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<ns0:helloResponse xmlns:ns0="http://test/">
<return>Hello World</return>
</ns0:helloResponse>
</soap:Body>
</soap:Envelope>
WSDL
:
-
Web Service Description Language.
-
It is a web grammar of specifying a
public interface of web service. This public interface can include information
on all publicly available functions, data type information for all XML
messages, binding information about the specific transport protocol to be used,
and address information for locating the specified Service.
-
WSDL is not necessarily tied to a
specific XML messaging system, but it does include built-in extensions
for describing SOAP services.
UDDI
:
-
UDDI currently represents the discovery
layer within the web service protocol stack.
-
UDDI was originally created by
Microsoft, IBM, and Ariba, and represents a technical specification for publishing and finding businesses and web services.
-
UDDI consists of two parts. First, UDDI is a technical specification for building a distribute directory of businesses and web services. Data is
stored within a specific XML format. The UDDI specification
includes API details for searching existing data and publishing new data.
-
Second, the UDDI Business Registry is a fully operational implementation of the
UDDI specification.
Accessing
a Web Service: Service Requester Perspective
Find a Web service
from UDDI
Retrieve WSDL or
XML-RPC human Instructions
Create a XML-RPC
or SOAP Client
Invoke Remote
Procedure Call
Creating
a Web service: Service Developer Perspective
Find the business functionality(business logic)
Now we will see about the elements of SOAP Messaging :
Ex:
Find the business functionality(business logic)
Create a XML-RPC or SOAP Service Wrapper
Create a WSDL or XML RPC Instructions
Deploy Service
Register new service via UDDI
SOAP :
- Soap is a XML -Based Protocol for exchanging information between computers.
- It can be used in variety of Messaging System and can be delivered in variety of Transport Protocols.
- It is Platform Independent.
- Soap can be implemented in any technologies such as Java,.NET,C++,Perl etc.
Soap Specification has "3" Major Parts.
1. Soap Envelope
2.Data Encoding Rules
3. RPC Conventions
1. Soap Envelope : A Soap Envelope contains the specific rules
for encapsulating data being transferred between computers.This includes
Application-Specific data ,such as Method name to invoke,Method
Parameters and return types.
2. Data Encoding Rules:
To exchange data, computers must agree on rules for encoding specific
data types.For example, two computers that process stock quotes need an
agreed-upon rule for encoding float data types; likewise, two computers
that process multiple stock quotes need an agreed-upon rule for encoding
arrays. SOAP therefore includes its own set of conventions for encoding
data types. Most of these conventions are based on the W3C XML Schema
specification.
3. RPC Conventions :
SOAP can be used in a variety of messaging systems, including one-way
and two way messaging. For two-way messaging, SOAP defines a simple
convention for representing remote procedure calls and responses. This
enables a client application to specify a remote method name, include
any number of parameters, and receive a response from the server.
Example :
A simple soap example which has the method "Temperature " and passes the
zip code in the request and gets the temperature in Response.
Request :
<?xml version='1.0' encoding='UTF-8'?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<SOAP-ENV:Body>
<ns1:getTemp
xmlns:ns1="urn:xmethods-Temperature"
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<zipcode xsi:type="xsd:string">10016</zipcode>
</ns1:getTemp>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
In this example couple of things have to be notice :
- The first line is the XML declaration with version and encoding.
- The second line contains mandatory "Soap Envelope"which has the details of all information which we need to pass.
- The Envelope contains different namespace which are required for making a soap request.
- The next line we have Soap body tag which again a mandatory data element.
- Next we have the Method name "Temperature" and parameter zip-code as String.
Note : We don't exactly need to know every thing happens in soap, but
basic understanding is important. So when we request a service from any
language we just access the method and pass the value behind the scenes
, request will formed in this manner and send to the service.
Response :
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<SOAP-ENV:Body>
<ns1:getTempResponse
xmlns:ns1="urn:xmethods-Temperature"
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<return xsi:type="xsd:float">71.0</return>
</ns1:getTempResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
As we can see , a response with float return type of Temp is
returned.From this Response we have to extract the data. This is how the
request and response happens in real world.
But, as i said when we access a web service from languages such as
java,c++ etc we don't really see what is happening in background we
formed the request using various web service API's and framework and
extract the response by the same way.
A Soap Message basically contains the following elements
1. Envelope - Mandatory
2. Headers - Optional
3. Body - Mandatory
4. Fault - Optional
1. Envelope :
- It is a root element of SOAP Messages.
- Soap uses XML namespaces to differentiate versions.
Ex:
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
The SOAP 1.1 namespace URI is http://schemas.xmlsoap.org/soap/envelope/,
whereas the SOAP 1.2 namespace URI is
http://www.w3.org/2001/09/soap-envelope.If the Envelope is in any other
namespace, it is considered a versioning error.
2. Headers :
- It is an optional element is Soap Messaging.
- The optional Header element offers a flexible framework for specifying additional
application-level requirements.
application-level requirements.
- For example, the Header element can be used to specify a digital signature for password-protected services.
-The Header framework provides an open mechanism for authentication, transaction management, and payment authorization.
It has "2" Main Attributes :
- Actor
- Must understand Attribute
Actor attribute:
The SOAP protocol defines a message path as a list of SOAP service
nodes. Each of these intermediate nodes can perform some processing and
then forward the message to the next node in the chain. By setting the
Actor attribute, the client can specify the recipient of the SOAP
header.
MustUnderstand attribute :
Indicates whether a Header element is optional or mandatory. If set to
true , the recipient must understand and process the Header attribute
according to its defined semantics, or return a fault.
SOAP 1.1 uses integer values of 1/0 for the MustUnderstand attribute; SOAP 1.2 uses Boolean values of true/1/false/0.
The Header specifies a payment account, which must be understood and processed by the SOAP server.
Here is an example Header :
<SOAP-ENV:Header>
<ns1:PaymentAccount xmlns:ns1="urn:ecerami" SOAP-ENV: mustUnderstand="true">
orsenigo473
</ns1:PaymentAccount >
</SOAP-ENV:Header>
<ns1:PaymentAccount xmlns:ns1="urn:ecerami" SOAP-ENV: mustUnderstand="true">
orsenigo473
</ns1:PaymentAccount >
</SOAP-ENV:Header>
3. Body :
The Body element is mandatory for all SOAP messages. As we have already seen, typical
uses of the Body element include RPC requests and responses.
uses of the Body element include RPC requests and responses.
<SOAP-ENV:Body>
<ns1:getTemp
xmlns:ns1="urn:xmethods-Temperature"
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<zipcode xsi:type="xsd:string">10016</zipcode>
</ns1:getTemp>
</SOAP-ENV:Body>
4. Fault :
- It is an optional element.
- In the event of an error, the Body element will include a Fault element.
- The following code is a sample Fault. The client has requested a method named
ValidateCreditCard , but the service does not support such a method.
ValidateCreditCard , but the service does not support such a method.
This represents a client request error, and the server returns the following SOAP response:
<?xml version='1.0' encoding='UTF-8'?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi="http://www.w3.org/1999/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/1999/XMLSchema">
<SOAP-ENV:Body>
<SOAP-ENV:Fault>
<faultcode xsi:type="xsd:string">SOAP-ENV:Client</faultcode>
<faultstring xsi:type="xsd:string">
Failed to locate method (ValidateCreditCard) in class
(examplesCreditCard) at /usr/local/ActivePerl-5.6/lib/
site_perl/5.6.0/SOAP/Lite.pm line 1555.
</faultstring>
</SOAP-ENV:Fault></SOAP-ENV:Body>
</SOAP-ENV:Envelope>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi="http://www.w3.org/1999/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/1999/XMLSchema">
<SOAP-ENV:Body>
<SOAP-ENV:Fault>
<faultcode xsi:type="xsd:string">SOAP-ENV:Client</faultcode>
<faultstring xsi:type="xsd:string">
Failed to locate method (ValidateCreditCard) in class
(examplesCreditCard) at /usr/local/ActivePerl-5.6/lib/
site_perl/5.6.0/SOAP/Lite.pm line 1555.
</faultstring>
</SOAP-ENV:Fault></SOAP-ENV:Body>
</SOAP-ENV:Envelope>
SOAP Fault codes :
SOAPENV: VersionMismatch
Indicates that the SOAP Envelope element included an invalid namespace, signifying a version mismatch.
Indicates that the SOAP Envelope element included an invalid namespace, signifying a version mismatch.
SOAPENV:MustUnderstand
Indicates that the recipient is unable to properly process a Header-element with a must-understand attribute set to true. This ensures that must-understand elements are not silently ignored.
Indicates that the recipient is unable to properly process a Header-element with a must-understand attribute set to true. This ensures that must-understand elements are not silently ignored.
SOAP-ENV:Client
Indicates that the client request contained an error. For example,the client has specified a nonexistent method name, or has supplied the incorrect parameters to the method.
Indicates that the client request contained an error. For example,the client has specified a nonexistent method name, or has supplied the incorrect parameters to the method.
SOAP-ENV:Server
Indicates that the server is unable to process the client request. For example, a service providing product data may be unable to connect to the database.
Indicates that the server is unable to process the client request. For example, a service providing product data may be unable to connect to the database.
SOAP :
- Soap is a XML -Based Protocol for exchanging information between computers.
- It can be used in variety of Messaging System and can be delivered in variety of Transport Protocols.
- It is Platform Independent.
- Soap can be implemented in any technologies such as Java,.NET,C++,Perl etc.
Soap Specification has "3" Major Parts.
1. Soap Envelope
2.Data Encoding Rules
3. RPC Conventions
1. Soap Envelope : A Soap Envelope contains the specific rules
for encapsulating data being transferred between computers.This includes
Application-Specific data ,such as Method name to invoke,Method
Parameters and return types.
2. Data Encoding Rules:
To exchange data, computers must agree on rules for encoding specific
data types.For example, two computers that process stock quotes need an
agreed-upon rule for encoding float data types; likewise, two computers
that process multiple stock quotes need an agreed-upon rule for encoding
arrays. SOAP therefore includes its own set of conventions for encoding
data types. Most of these conventions are based on the W3C XML Schema
specification.
3. RPC Conventions :
SOAP can be used in a variety of messaging systems, including one-way
and two way messaging. For two-way messaging, SOAP defines a simple
convention for representing remote procedure calls and responses. This
enables a client application to specify a remote method name, include
any number of parameters, and receive a response from the server.
Example :
A simple soap example which has the method "Temperature " and passes the
zip code in the request and gets the temperature in Response.
Request :
<?xml version='1.0' encoding='UTF-8'?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<SOAP-ENV:Body>
<ns1:getTemp
xmlns:ns1="urn:xmethods-Temperature"
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<zipcode xsi:type="xsd:string">10016</zipcode>
</ns1:getTemp>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
In this example couple of things have to be notice :
- The first line is the XML declaration with version and encoding.
- The second line contains mandatory "Soap Envelope"which has the details of all information which we need to pass.
- The Envelope contains different namespace which are required for making a soap request.
- The next line we have Soap body tag which again a mandatory data element.
- Next we have the Method name "Temperature" and parameter zip-code as String.
Note : We don't exactly need to know every thing happens in soap, but
basic understanding is important. So when we request a service from any
language we just access the method and pass the value behind the scenes
, request will formed in this manner and send to the service.
Response :
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<SOAP-ENV:Body>
<ns1:getTempResponse
xmlns:ns1="urn:xmethods-Temperature"
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<return xsi:type="xsd:float">71.0</return>
</ns1:getTempResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
As we can see , a response with float return type of Temp is
returned.From this Response we have to extract the data. This is how the
request and response happens in real world.
But, as i said when we access a web service from languages such as
java,c++ etc we don't really see what is happening in background we
formed the request using various web service API's and framework and
extract the response by the same way.
A Soap Message basically contains the following elements
1. Envelope - Mandatory
2. Headers - Optional
3. Body - Mandatory
4. Fault - Optional
1. Envelope :
- It is a root element of SOAP Messages.
- Soap uses XML namespaces to differentiate versions.
Ex:
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
The SOAP 1.1 namespace URI is http://schemas.xmlsoap.org/soap/envelope/,
whereas the SOAP 1.2 namespace URI is
http://www.w3.org/2001/09/soap-envelope.If the Envelope is in any other
namespace, it is considered a versioning error.
2. Headers :
- It is an optional element is Soap Messaging.
- The optional Header element offers a flexible framework for specifying additional
application-level requirements.
application-level requirements.
- For example, the Header element can be used to specify a digital signature for password-protected services.
-The Header framework provides an open mechanism for authentication, transaction management, and payment authorization.
It has "2" Main Attributes :
- Actor
- Must understand Attribute
Actor attribute:
The SOAP protocol defines a message path as a list of SOAP service
nodes. Each of these intermediate nodes can perform some processing and
then forward the message to the next node in the chain. By setting the
Actor attribute, the client can specify the recipient of the SOAP
header.
MustUnderstand attribute :
Indicates whether a Header element is optional or mandatory. If set to
true , the recipient must understand and process the Header attribute
according to its defined semantics, or return a fault.
SOAP 1.1 uses integer values of 1/0 for the MustUnderstand attribute; SOAP 1.2 uses Boolean values of true/1/false/0.
The Header specifies a payment account, which must be understood and processed by the SOAP server.
Here is an example Header :
<SOAP-ENV:Header>
<ns1:PaymentAccount xmlns:ns1="urn:ecerami" SOAP-ENV: mustUnderstand="true">
orsenigo473
</ns1:PaymentAccount >
</SOAP-ENV:Header>
<ns1:PaymentAccount xmlns:ns1="urn:ecerami" SOAP-ENV: mustUnderstand="true">
orsenigo473
</ns1:PaymentAccount >
</SOAP-ENV:Header>
3. Body :
The Body element is mandatory for all SOAP messages. As we have already seen, typical
uses of the Body element include RPC requests and responses.
uses of the Body element include RPC requests and responses.
<SOAP-ENV:Body>
<ns1:getTemp
xmlns:ns1="urn:xmethods-Temperature"
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<zipcode xsi:type="xsd:string">10016</zipcode>
</ns1:getTemp>
</SOAP-ENV:Body>
4. Fault :
- It is an optional element.
- In the event of an error, the Body element will include a Fault element.
- The following code is a sample Fault. The client has requested a method named
ValidateCreditCard , but the service does not support such a method.
ValidateCreditCard , but the service does not support such a method.
This represents a client request error, and the server returns the following SOAP response:
<?xml version='1.0' encoding='UTF-8'?>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi="http://www.w3.org/1999/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/1999/XMLSchema">
<SOAP-ENV:Body>
<SOAP-ENV:Fault>
<faultcode xsi:type="xsd:string">SOAP-ENV:Client</faultcode>
<faultstring xsi:type="xsd:string">
Failed to locate method (ValidateCreditCard) in class
(examplesCreditCard) at /usr/local/ActivePerl-5.6/lib/
site_perl/5.6.0/SOAP/Lite.pm line 1555.
</faultstring>
</SOAP-ENV:Fault></SOAP-ENV:Body>
</SOAP-ENV:Envelope>
<SOAP-ENV:Envelope
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:xsi="http://www.w3.org/1999/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/1999/XMLSchema">
<SOAP-ENV:Body>
<SOAP-ENV:Fault>
<faultcode xsi:type="xsd:string">SOAP-ENV:Client</faultcode>
<faultstring xsi:type="xsd:string">
Failed to locate method (ValidateCreditCard) in class
(examplesCreditCard) at /usr/local/ActivePerl-5.6/lib/
site_perl/5.6.0/SOAP/Lite.pm line 1555.
</faultstring>
</SOAP-ENV:Fault></SOAP-ENV:Body>
</SOAP-ENV:Envelope>
SOAP Fault codes :
SOAPENV: VersionMismatch
Indicates that the SOAP Envelope element included an invalid namespace, signifying a version mismatch.
Indicates that the SOAP Envelope element included an invalid namespace, signifying a version mismatch.
SOAPENV:MustUnderstand
Indicates that the recipient is unable to properly process a Header-element with a must-understand attribute set to true. This ensures that must-understand elements are not silently ignored.
Indicates that the recipient is unable to properly process a Header-element with a must-understand attribute set to true. This ensures that must-understand elements are not silently ignored.
SOAP-ENV:Client
Indicates that the client request contained an error. For example,the client has specified a nonexistent method name, or has supplied the incorrect parameters to the method.
Indicates that the client request contained an error. For example,the client has specified a nonexistent method name, or has supplied the incorrect parameters to the method.
SOAP-ENV:Server
Indicates that the server is unable to process the client request. For example, a service providing product data may be unable to connect to the database.
Indicates that the server is unable to process the client request. For example, a service providing product data may be unable to connect to the database.
WSDL :
WSDL stands for Web Services Description Language
WSDL is an XML based protocol for information exchange in decentralized and distributed environments.
WSDL is the standard format for describing a web service.
WSDL is an interface provided by the webservice publisher to the clients .Using this interface client can understands what are they type of operation the webservice is offering.
WSDL is declard as a part of UDDI while registering the webservice in UDDI.
WSDL Elements:
Three major elements of WSDL that can be defined separately and they are:
a.Types - It contains all the datatypes specification what type of values methods accepts.
b.Operations - Define the Methods provided by the Webservice and it's input parameters and it's result.
c.Binding - Contains the end point URL of the webservice .
Apart from these WSDL also have other elements.
Definition: This element must be the root element of all WSDL documents. It defines the name of the web service, declares multiple namespaces used throughout the remainder of the document, and contains all the service elements described here.
Data types(xsd): the data types - in the form of XML schemas(xsd) or possibly some other mechanism - to be used in the messages. This can define inside the WSDL or can refer from external location.
Message: an abstract definition of the data, in the form of a message presented either as an entire document or as arguments to be mapped to a method invocation.
Operation: the abstract definition of the operation for a message, such as naming a method, message queue, or business process, that will accept and process the message
Port type : an abstract set of operations mapped to one or more end points, defining the collection of operations for a binding; the collection of operations, because it is abstract, can be mapped to multiple transports through various bindings.
Binding: the concrete protocol and data formats for the operations and messages defined for a particular port type.
Port: a combination of a binding and a network address, providing the target address of the service communication.
Service: a collection of related end points encompassing the service definitions in the file; the services map the binding to the port and include any extensibility definitions.
In addition to these major elements, the WSDL specification also defines the following utility elements:
Documentation: element is used to provide human-readable documentation and can be included inside any other WSDL element.
Import: element is used to import other WSDL documents or XML Schemas.
Ex:
<?xml version="1.0" encoding="utf-8"?>
<wsdl:definitions xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:tm="http://microsoft.com/wsdl/mime/textMatching/" xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/" xmlns:mime="http://schemas.xmlsoap.org/wsdl/mime/" xmlns:tns="http://tempuri.org/" xmlns:s="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://schemas.xmlsoap.org/wsdl/soap12/" xmlns:http="http://schemas.xmlsoap.org/wsdl/http/" targetNamespace="http://tempuri.org/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/">
<wsdl:types>
<s:schema elementFormDefault="qualified" targetNamespace="http://tempuri.org/">
<s:element name="FahrenheitToCelsius">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="Fahrenheit" type="s:string" />
</s:sequence>
</s:complexType>
</s:element>
<s:element name="FahrenheitToCelsiusResponse">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="FahrenheitToCelsiusResult" type="s:string" />
</s:sequence>
</s:complexType>
</s:element>
<s:element name="CelsiusToFahrenheit">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="Celsius" type="s:string" />
</s:sequence>
</s:complexType>
</s:element>
<s:element name="CelsiusToFahrenheitResponse">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="CelsiusToFahrenheitResult" type="s:string" />
</s:sequence>
</s:complexType>
</s:element>
<s:element name="string" nillable="true" type="s:string" />
</s:schema>
</wsdl:types>
<wsdl:message name="FahrenheitToCelsiusSoapIn">
<wsdl:part name="parameters" element="tns:FahrenheitToCelsius" />
</wsdl:message>
<wsdl:message name="FahrenheitToCelsiusSoapOut">
<wsdl:part name="parameters" element="tns:FahrenheitToCelsiusResponse" />
</wsdl:message>
<wsdl:message name="CelsiusToFahrenheitSoapIn">
<wsdl:part name="parameters" element="tns:CelsiusToFahrenheit" />
</wsdl:message>
<wsdl:message name="CelsiusToFahrenheitSoapOut">
<wsdl:part name="parameters" element="tns:CelsiusToFahrenheitResponse" />
</wsdl:message>
<wsdl:message name="FahrenheitToCelsiusHttpPostIn">
<wsdl:part name="Fahrenheit" type="s:string" />
</wsdl:message>
<wsdl:message name="FahrenheitToCelsiusHttpPostOut">
<wsdl:part name="Body" element="tns:string" />
</wsdl:message>
<wsdl:message name="CelsiusToFahrenheitHttpPostIn">
<wsdl:part name="Celsius" type="s:string" />
</wsdl:message>
<wsdl:message name="CelsiusToFahrenheitHttpPostOut">
<wsdl:part name="Body" element="tns:string" />
</wsdl:message>
<wsdl:portType name="TempConvertSoap">
<wsdl:operation name="FahrenheitToCelsius">
<wsdl:input message="tns:FahrenheitToCelsiusSoapIn" />
<wsdl:output message="tns:FahrenheitToCelsiusSoapOut" />
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<wsdl:input message="tns:CelsiusToFahrenheitSoapIn" />
<wsdl:output message="tns:CelsiusToFahrenheitSoapOut" />
</wsdl:operation>
</wsdl:portType>
<wsdl:portType name="TempConvertHttpPost">
<wsdl:operation name="FahrenheitToCelsius">
<wsdl:input message="tns:FahrenheitToCelsiusHttpPostIn" />
<wsdl:output message="tns:FahrenheitToCelsiusHttpPostOut" />
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<wsdl:input message="tns:CelsiusToFahrenheitHttpPostIn" />
<wsdl:output message="tns:CelsiusToFahrenheitHttpPostOut" />
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name="TempConvertSoap" type="tns:TempConvertSoap">
<soap:binding transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="FahrenheitToCelsius">
<soap:operation soapAction="http://tempuri.org/FahrenheitToCelsius" style="document" />
<wsdl:input>
<soap:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<soap:operation soapAction="http://tempuri.org/CelsiusToFahrenheit" style="document" />
<wsdl:input>
<soap:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:binding name="TempConvertSoap12" type="tns:TempConvertSoap">
<soap12:binding transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="FahrenheitToCelsius">
<soap12:operation soapAction="http://tempuri.org/FahrenheitToCelsius" style="document" />
<wsdl:input>
<soap12:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap12:body use="literal" />
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<soap12:operation soapAction="http://tempuri.org/CelsiusToFahrenheit" style="document" />
<wsdl:input>
<soap12:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap12:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:binding name="TempConvertHttpPost" type="tns:TempConvertHttpPost">
<http:binding verb="POST" />
<wsdl:operation name="FahrenheitToCelsius">
<http:operation location="/FahrenheitToCelsius" />
<wsdl:input>
<mime:content type="application/x-www-form-urlencoded" />
</wsdl:input>
<wsdl:output>
<mime:mimeXml part="Body" />
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<http:operation location="/CelsiusToFahrenheit" />
<wsdl:input>
<mime:content type="application/x-www-form-urlencoded" />
</wsdl:input>
<wsdl:output>
<mime:mimeXml part="Body" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name="TempConvert">
<wsdl:port name="TempConvertSoap" binding="tns:TempConvertSoap">
<soap:address location="http://www.w3schools.com/webservices/tempconvert.asmx" />
</wsdl:port>
<wsdl:port name="TempConvertSoap12" binding="tns:TempConvertSoap12">
<soap12:address location="http://www.w3schools.com/webservices/tempconvert.asmx" />
</wsdl:port>
<wsdl:port name="TempConvertHttpPost" binding="tns:TempConvertHttpPost">
<http:address location="http://www.w3schools.com/webservices/tempconvert.asmx" />
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
The following wsdl is obtained from the webservice TempConvert of w3schools.com
URL : http://www.w3schools.com/webservices/tempconvert.asmx?WSDL
Now,examine this WSDL closely.
wsdl definition- This contains lot of name space we don't need to care about this,these are all can be added/generated by tools. Generally a WSDL is generated by Tools.But we need to understand it content which help us to write the client code.
wsdl types : This contains the in-built xsd(Xml Schema Definition)for the types methods accept.We will discuss about XSD in detail in next part.
wsdl message : This contains the message name which can refer at various place for mention the types of input and output parameters for webservice methods.
wsdl operation : It contains the Methods provided by the webservice.
wsdl input/output : It contains the Methods inputs and output parameter name and it's type.Normally in big WSDL it being refer in external xsd's.
Other elements we actually no need to worry.Since once we obtained the WSDL ,next thing we have to do is generate java classes from it .It can done by tools.Once we obtained the java classes we can write the client code easily and make a request to the webservice.
WSDL stands for Web Services Description Language
WSDL is an XML based protocol for information exchange in decentralized and distributed environments.
WSDL is the standard format for describing a web service.
WSDL is an interface provided by the webservice publisher to the clients .Using this interface client can understands what are they type of operation the webservice is offering.
WSDL is declard as a part of UDDI while registering the webservice in UDDI.
WSDL Elements:
Three major elements of WSDL that can be defined separately and they are:
a.Types - It contains all the datatypes specification what type of values methods accepts.
b.Operations - Define the Methods provided by the Webservice and it's input parameters and it's result.
c.Binding - Contains the end point URL of the webservice .
Apart from these WSDL also have other elements.
Definition: This element must be the root element of all WSDL documents. It defines the name of the web service, declares multiple namespaces used throughout the remainder of the document, and contains all the service elements described here.
Data types(xsd): the data types - in the form of XML schemas(xsd) or possibly some other mechanism - to be used in the messages. This can define inside the WSDL or can refer from external location.
Message: an abstract definition of the data, in the form of a message presented either as an entire document or as arguments to be mapped to a method invocation.
Operation: the abstract definition of the operation for a message, such as naming a method, message queue, or business process, that will accept and process the message
Port type : an abstract set of operations mapped to one or more end points, defining the collection of operations for a binding; the collection of operations, because it is abstract, can be mapped to multiple transports through various bindings.
Binding: the concrete protocol and data formats for the operations and messages defined for a particular port type.
Port: a combination of a binding and a network address, providing the target address of the service communication.
Service: a collection of related end points encompassing the service definitions in the file; the services map the binding to the port and include any extensibility definitions.
In addition to these major elements, the WSDL specification also defines the following utility elements:
Documentation: element is used to provide human-readable documentation and can be included inside any other WSDL element.
Import: element is used to import other WSDL documents or XML Schemas.
Ex:
<?xml version="1.0" encoding="utf-8"?>
<wsdl:definitions xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:tm="http://microsoft.com/wsdl/mime/textMatching/" xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/" xmlns:mime="http://schemas.xmlsoap.org/wsdl/mime/" xmlns:tns="http://tempuri.org/" xmlns:s="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://schemas.xmlsoap.org/wsdl/soap12/" xmlns:http="http://schemas.xmlsoap.org/wsdl/http/" targetNamespace="http://tempuri.org/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/">
<wsdl:types>
<s:schema elementFormDefault="qualified" targetNamespace="http://tempuri.org/">
<s:element name="FahrenheitToCelsius">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="Fahrenheit" type="s:string" />
</s:sequence>
</s:complexType>
</s:element>
<s:element name="FahrenheitToCelsiusResponse">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="FahrenheitToCelsiusResult" type="s:string" />
</s:sequence>
</s:complexType>
</s:element>
<s:element name="CelsiusToFahrenheit">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="Celsius" type="s:string" />
</s:sequence>
</s:complexType>
</s:element>
<s:element name="CelsiusToFahrenheitResponse">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="CelsiusToFahrenheitResult" type="s:string" />
</s:sequence>
</s:complexType>
</s:element>
<s:element name="string" nillable="true" type="s:string" />
</s:schema>
</wsdl:types>
<wsdl:message name="FahrenheitToCelsiusSoapIn">
<wsdl:part name="parameters" element="tns:FahrenheitToCelsius" />
</wsdl:message>
<wsdl:message name="FahrenheitToCelsiusSoapOut">
<wsdl:part name="parameters" element="tns:FahrenheitToCelsiusResponse" />
</wsdl:message>
<wsdl:message name="CelsiusToFahrenheitSoapIn">
<wsdl:part name="parameters" element="tns:CelsiusToFahrenheit" />
</wsdl:message>
<wsdl:message name="CelsiusToFahrenheitSoapOut">
<wsdl:part name="parameters" element="tns:CelsiusToFahrenheitResponse" />
</wsdl:message>
<wsdl:message name="FahrenheitToCelsiusHttpPostIn">
<wsdl:part name="Fahrenheit" type="s:string" />
</wsdl:message>
<wsdl:message name="FahrenheitToCelsiusHttpPostOut">
<wsdl:part name="Body" element="tns:string" />
</wsdl:message>
<wsdl:message name="CelsiusToFahrenheitHttpPostIn">
<wsdl:part name="Celsius" type="s:string" />
</wsdl:message>
<wsdl:message name="CelsiusToFahrenheitHttpPostOut">
<wsdl:part name="Body" element="tns:string" />
</wsdl:message>
<wsdl:portType name="TempConvertSoap">
<wsdl:operation name="FahrenheitToCelsius">
<wsdl:input message="tns:FahrenheitToCelsiusSoapIn" />
<wsdl:output message="tns:FahrenheitToCelsiusSoapOut" />
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<wsdl:input message="tns:CelsiusToFahrenheitSoapIn" />
<wsdl:output message="tns:CelsiusToFahrenheitSoapOut" />
</wsdl:operation>
</wsdl:portType>
<wsdl:portType name="TempConvertHttpPost">
<wsdl:operation name="FahrenheitToCelsius">
<wsdl:input message="tns:FahrenheitToCelsiusHttpPostIn" />
<wsdl:output message="tns:FahrenheitToCelsiusHttpPostOut" />
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<wsdl:input message="tns:CelsiusToFahrenheitHttpPostIn" />
<wsdl:output message="tns:CelsiusToFahrenheitHttpPostOut" />
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name="TempConvertSoap" type="tns:TempConvertSoap">
<soap:binding transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="FahrenheitToCelsius">
<soap:operation soapAction="http://tempuri.org/FahrenheitToCelsius" style="document" />
<wsdl:input>
<soap:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<soap:operation soapAction="http://tempuri.org/CelsiusToFahrenheit" style="document" />
<wsdl:input>
<soap:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:binding name="TempConvertSoap12" type="tns:TempConvertSoap">
<soap12:binding transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="FahrenheitToCelsius">
<soap12:operation soapAction="http://tempuri.org/FahrenheitToCelsius" style="document" />
<wsdl:input>
<soap12:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap12:body use="literal" />
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<soap12:operation soapAction="http://tempuri.org/CelsiusToFahrenheit" style="document" />
<wsdl:input>
<soap12:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap12:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:binding name="TempConvertHttpPost" type="tns:TempConvertHttpPost">
<http:binding verb="POST" />
<wsdl:operation name="FahrenheitToCelsius">
<http:operation location="/FahrenheitToCelsius" />
<wsdl:input>
<mime:content type="application/x-www-form-urlencoded" />
</wsdl:input>
<wsdl:output>
<mime:mimeXml part="Body" />
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="CelsiusToFahrenheit">
<http:operation location="/CelsiusToFahrenheit" />
<wsdl:input>
<mime:content type="application/x-www-form-urlencoded" />
</wsdl:input>
<wsdl:output>
<mime:mimeXml part="Body" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name="TempConvert">
<wsdl:port name="TempConvertSoap" binding="tns:TempConvertSoap">
<soap:address location="http://www.w3schools.com/webservices/tempconvert.asmx" />
</wsdl:port>
<wsdl:port name="TempConvertSoap12" binding="tns:TempConvertSoap12">
<soap12:address location="http://www.w3schools.com/webservices/tempconvert.asmx" />
</wsdl:port>
<wsdl:port name="TempConvertHttpPost" binding="tns:TempConvertHttpPost">
<http:address location="http://www.w3schools.com/webservices/tempconvert.asmx" />
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
The following wsdl is obtained from the webservice TempConvert of w3schools.com
URL : http://www.w3schools.com/webservices/tempconvert.asmx?WSDL
Now,examine this WSDL closely.
wsdl definition- This contains lot of name space we don't need to care about this,these are all can be added/generated by tools. Generally a WSDL is generated by Tools.But we need to understand it content which help us to write the client code.
wsdl types : This contains the in-built xsd(Xml Schema Definition)for the types methods accept.We will discuss about XSD in detail in next part.
wsdl message : This contains the message name which can refer at various place for mention the types of input and output parameters for webservice methods.
wsdl operation : It contains the Methods provided by the webservice.
wsdl input/output : It contains the Methods inputs and output parameter name and it's type.Normally in big WSDL it being refer in external xsd's.
Other elements we actually no need to worry.Since once we obtained the WSDL ,next thing we have to do is generate java classes from it .It can done by tools.Once we obtained the java classes we can write the client code easily and make a request to the webservice.
XSD :
It is used in WSDL Document to define the data types of Method takes .Such as Input Parameters data types,Output Parameter data types,attribute types and return types.
It defines element that can appear in Document.
It defines attributes that can appear in the Document.
It defines the order of Child element and define no.of child elements.
It defines whether an elemnt is empty or can include text.
It defines default and fixed value for elements and attributes.
It can define in the WSDL itself or it can be refer externally by importing the XSD URL in the WSDL just like JavaScript and CSS.
It's an alternative to DTD's.More Powerful then DTD.(Document Type Definition)
Multiple Schema's can refer in one WSDL.Allows re-usability.Allow Namespace.
We can define our own dataype derived from the standard types.
Root Element of XSD :
<schema> : This is the root element of any XML Schema Document.It can contain attribute also.
Syntax:
<? xml version="1.0" ? >
<xs:schema>
------
------
</xs:schema>
Ex:
<?xml version="1.0"?>
<xs:schema xmlns:"http://www.w3.org/2001/XMLSchema" targetNameSpace="http://www.ayaz.com" xmlns="http://www.ayaz.com" elementFromDefault="qualified">
...............
...............
</xs:schema>
Here xs:schema xmlns follows the namespace define the w3 standards. targetNamspace schema defines the elements defines by this schema comes from ayaz.com.elementfromDefault specifies that every element should be namespace qualified.
Simple Example : (note.xml)
------------------------------------
<?xml version="1.0"?>
<note>
<from>Tom</from>
<to>Jack</to>
<heading>Remainders</heading>
<body> Dont'forget</body>
</note>
note.xsd : Defines element for note.xml
<?xml version="1.0"?>
<xs:schema xmlns:"http://www.w3.org/2001/XMLSchema" targetNameSpace="http://www.ayaz.com" xmlns="http://www.ayaz.com" elementFromDefault="qualified">
.
<xs:element name="note">
<xs:complexType>
<xs:sequence>
<xs:element name="to" type="xs:String"/>
<xs:element name="from" type="xs:String/>
<xs:element name="heading" type="xs:String/>
<xs:element name="body" type="xs:String/>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
We will look on each of the element in detail in later part.So i have the xsd for my xml element now i can refer in my Document .
<?xml version="1.0"?>
< note xmlns="http://www.ayaz.com" xmlns=xsi="http://www.w3org.2001/XMLSchema-instance"
xsi:schemaLocation="http://www.ayaz.com/note.xsd">
<from>Tom</from>
<to>Jack</to>
<heading>Remainders</heading>
<body> Dont'forget</body>
</note>
Red color highlighted - tells the Schema validator that all elements used in this XML Document are declared in "http://www.ayaz.com"
Blue color highlighted - tells once you have the XML Schema instances we can use the SchemaLocation Attribute.
Brown Color highlighted - tells the namespace used for the xsd and it's location.
2. XSD Elements:
XSD elements can be classified as "Single" and Complex" Element.
a.Simple Element :
A Simple element does not have any attribute and other elements.
It can contain only Text.The Text can be of any type (String,boolean,Int)or it can be custom type define by the user.
We can also add restrictions such as limit the content or to match the specific pattern.
Synatx:
<xs:element name="------ " type="------"/>
Ex: <xs:element name="firstname" type="xs:String"/>
Default & Fixed Value :
Default - This value is taken when there is no value is provided.
Fixed - This value is taken assigned automatically to the element and cannot assign other values.
Ex:
<xs:element name="firstname" type="xs:String" default="John "/>
<xs:element name="color" type="xs:String" fixed="red"/>
b. XSD Attributes:
Simple elements cannot have attributes. If an element is specified with attribute then it is considered ad complex type element.But a attribute always declared as simple type.
Synatx :
<xs:attribute name="-----" type="----"/>
Ex:
<xs:attribute name="lang" type="xs:String" />
<lastname lang="en">Smith</lastname> -- Refering in XML Document.
Note: Default and fixed behave same way as the does for simple element.
Optional & required
Attribute can be specify as optional or required one.Attributes are optional by default to make the attribute declared as required we should declared by the "use" keyword.
<xs:attribute name="lang" type="xs:String" use="required'/>
c. XSD Restrictions /Facets :
<xs:restriction> is used to set restrcitions.
Restriction on Simple Element
Ex: To accept values between 0-120
<xs:element name="age">
<xs:simpleType>
<xs:restriction base="xs:integer">
<xs:minInclusive value="0"/>
<xs:maxInclusive value="120"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
To set Restrictions on set of values use the enumeration
<xs:element name="car">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:enumeration value="Audi"/>
<xs:enumeration value="Golf"/>
<xs:enumeration value="BMW"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
Length Restriction
<xs:element name="password">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:length value="8"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
Constraint Description
3. Complex XSD Elements :
A complex element is an XML element that contains other elements and/or attributes.
There are four kinds of complex elements:
An empty complex element cannot have contents, only attributes.
An empty XML element
<product prodid="1345" />
Ex:
<xs:element name="product">
<xs:complexType>
<xs:attribute name="prodid" type="xs:positiveInteger"/>
</xs:complexType>
</xs:element>
Element which have elements only :
An "elements-only" complex type contains an element that contains only other elements.
An XML element, "person", that contains only other elements:
You can define the "person" element in a schema, like this:
Text- Only :
This type contains only simple content (text and attributes), therefore we add a simpleContent element around the content. When using simple content, you must define an extension OR a restriction within the simpleContent element, like this:
An XML element, "letter", that contains both text and other elements:
The following schema declares the "letter" element:
<xs:complexType mixed="true">
<xs:sequence>
<xs:element name="name" type="xs:string"/>
<xs:element name="orderid" type="xs:positiveInteger"/>
<xs:element name="shipdate" type="xs:date"/>
</xs:sequence>
</xs:complexType>
</xs:element>
4 . Indicators
There are seven indicators:
Order indicators:
Mostly Used indicators are discussed below :
Sequence Indicator
The <sequence> indicator specifies that the child elements must appear in a specific order:
Occurence Indicator
Occurrence indicators are used to define how often an element can occur.
maxOccurs Indicator
The <maxOccurs> indicator specifies the maximum number of times an element can occur:
The example above indicates that the "child_name" element
can occur a minimum of one time (the default value for minOccurs
is 1) and a maximum of ten times in the "person" element.
minOccurs Indicator
The <minOccurs> indicator specifies the minimum number of times an element can occur:
The example above indicates that the "child_name" element can occur
a minimum of zero times and a maximum of ten times in the "person" element.
To allow an element to appear an unlimited number of times, use the maxOccurs="unbounded" statement
wsimport :
This tool is come along with the jdk.If you have install the JDK properly and your classpath or JAVA_HOME variable is set you can see the list of options provided by this command by typing wsimport in the command prompt.
For generating Java classess from wsimport the syntax is :
wsimport wsdl-location-path -d -keep
The wsdl-location-path : Is the location of wsdl file existence.
-d : specify the directory where all the generated classes should be placed.
-keep : It will keep the java source code of generated classes in the respective directory mentioned.
-extension :allow vendor extension - functionality if not have been specified.
Ex:
wsimport hello.wsdl src -keep
Now we will take the sample webservice of w3schools which has the follwing wsdl location:
http://www.w3schools.com/webservices/tempconvert.asmx?WSDL
Execute the command in DOS Prompt to generate classes from wsdl :
C:\webservice> wsimport http://www.w3schools.com/webservices/tempconvert.asmx?WSDL -extension -keep
After execution it will create a folder called org inside the webs service folder.
Now Create a Main class to access these webservice :
Code:
import org.tempuri.*;
public class Main {
public static void main(String a[])
{
TempConvert convert=new TempConvert();
System.out.println(convert.getTempConvertSoap().celsiusToFahrenheit("122"));
}
}
Save these class inside "webservice" folder .Compile and run it you will see the output as "251.6" returning from web service.
Result :
Well, There are many ways to write a webservice, but it all depends upon
the what kind of business logic and what kind of stuff your webservice
wants to provide. They are two types of webservice available in the
market as for now they are:
1.SOAP
2.REST
Here we will be creating SOAP based Web Service.What is SOAP and how it's work we have already seen,you can refer links in our index page. As per REST we will see in later part of our tutorials.
In this section we will concentrating on writing a Java webservice based upon a Java class which has a business method from this class a webservice we are going to create ,which can be access by many for there needs.
We are going to follow the eclipse Bottom approach to create this webservice.
Bottom-Up-Approach : It is used to create a webservice & WSDL from a Java class.
So before we begin we need the following
Requirements:
1. Eclipse IDE with J2EE Plugins or Eclipse Indigo J2EE Version [http://www.eclipse.org]
2.A Webserver or Application Server (Here i am using Tomcat Webserver)
Once we are done with our first webservice. We will access it through SOAP UI.We have already discuss about SOAPUI functionality in previous tutorials you can refer from here :
http://ayazroomy-java.blogspot.in/2013/07/java-web-service-tutorial-with-soap-ui.html
Now, Once you have the Eclipse IDE , You should configure the Tomcat Server in the Eclipse by Adding the Server in the Server TAB.So now we have the Server ready ....
Now create a new WebProject by :
Step 1:
File -> New -> Dynamic WebProject
Give a Name to the Project say : MyService and click the "Finish" Button.
Step 2:
Create a Package called "com.test" under "src" folder of "MyService" WebApplication.
Create a new Class called "Display" under "com.test" package.
Display class :
package com.test;
public class Display {
public String convert(String name)
{
return name.toUpperCase();
}
}
It is a straight forward simple class having a single business method which accepts a String and returns a String in Upper Case format.
Step 3:
Now, Right click on the Project "MyService"[Project Name] node and select the following :
New -> Other -> Webservices -> WebService : It will show a WebService Window
In this window we have couple of options:
1. Select the WebService Type as: BottomUp Java Bean Service
2. Select the class you have created now here namely : "Display By clicking on the Browse Button"
There are 3 Configuration links available in this window:
- ServerRuntime : Select your server in this case we have use Tomcat
- Service Runtime : Apache Axis - Default it will be selected
-Service Project : Specify your Project name here "MyService" and Click the Next Button >>
Step 4:
Follow instructions in screen shot below. Click Next Button ...
Step 5 :
After successful deployment the publishing window will appear.Now click the Finish Button
Now you can a wsdl namely Display.wsdl will be generated inside the wsdl folder under the WebContent Directory of the Project "MyService".
Display.wsdl :
<?xml version="1.0" encoding="UTF-8"?>
<wsdl:definitions targetNamespace="http://test.com" xmlns:apachesoap="http://xml.apache.org/xml-soap" xmlns:impl="http://test.com" xmlns:intf="http://test.com" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:wsdlsoap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<!--WSDL created by Apache Axis version: 1.4
Built on Apr 22, 2006 (06:55:48 PDT)-->
<wsdl:types>
<schema elementFormDefault="qualified" targetNamespace="http://test.com" xmlns="http://www.w3.org/2001/XMLSchema">
<element name="convert">
<complexType>
<sequence>
<element name="name" type="xsd:string"/>
</sequence>
</complexType>
</element>
<element name="convertResponse">
<complexType>
<sequence>
<element name="convertReturn" type="xsd:string"/>
</sequence>
</complexType>
</element>
</schema>
</wsdl:types>
<wsdl:message name="convertRequest">
<wsdl:part element="impl:convert" name="parameters">
</wsdl:part>
</wsdl:message>
<wsdl:message name="convertResponse">
<wsdl:part element="impl:convertResponse" name="parameters">
</wsdl:part>
</wsdl:message>
<wsdl:portType name="Display">
<wsdl:operation name="convert">
<wsdl:input message="impl:convertRequest" name="convertRequest">
</wsdl:input>
<wsdl:output message="impl:convertResponse" name="convertResponse">
</wsdl:output>
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name="DisplaySoapBinding" type="impl:Display">
<wsdlsoap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/>
<wsdl:operation name="convert">
<wsdlsoap:operation soapAction=""/>
<wsdl:input name="convertRequest">
<wsdlsoap:body use="literal"/>
</wsdl:input>
<wsdl:output name="convertResponse">
<wsdlsoap:body use="literal"/>
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name="DisplayService">
<wsdl:port binding="impl:DisplaySoapBinding" name="Display">
<wsdlsoap:address location="http://localhost:8080/MyService/services/Display"/>
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
Now in the browser if you type the URL :
http://localhost:8080/MyService/services . We can see list of Deployed Services in the Server.
Now, we have the service ready , now we can test this through SOAP UI.
Step 6:
- Open SOAP UI.
- Right Click on Project Node->New SoapUI Project --> Provide the WSDL Location Path .
- In this case http://localhost:8080/MyService/services/Display?wsdl
Open the Soap Request give some name in lower case in request XML and we can see the Response in Upper case for the given name.
We can create stub for this Webservice by using wsimport tool please refer http://ayazroomy-java.blogspot.in/2013/07/using-wsimport-tool-to-generate-client.html for creating Stub and client from WSDL.
It is used in WSDL Document to define the data types of Method takes .Such as Input Parameters data types,Output Parameter data types,attribute types and return types.
It defines element that can appear in Document.
It defines attributes that can appear in the Document.
It defines the order of Child element and define no.of child elements.
It defines whether an elemnt is empty or can include text.
It defines default and fixed value for elements and attributes.
It can define in the WSDL itself or it can be refer externally by importing the XSD URL in the WSDL just like JavaScript and CSS.
It's an alternative to DTD's.More Powerful then DTD.(Document Type Definition)
Multiple Schema's can refer in one WSDL.Allows re-usability.Allow Namespace.
We can define our own dataype derived from the standard types.
Root Element of XSD :
<schema> : This is the root element of any XML Schema Document.It can contain attribute also.
Syntax:
<? xml version="1.0" ? >
<xs:schema>
------
------
</xs:schema>
Ex:
<?xml version="1.0"?>
<xs:schema xmlns:"http://www.w3.org/2001/XMLSchema" targetNameSpace="http://www.ayaz.com" xmlns="http://www.ayaz.com" elementFromDefault="qualified">
...............
...............
</xs:schema>
Here xs:schema xmlns follows the namespace define the w3 standards. targetNamspace schema defines the elements defines by this schema comes from ayaz.com.elementfromDefault specifies that every element should be namespace qualified.
Simple Example : (note.xml)
------------------------------------
<?xml version="1.0"?>
<note>
<from>Tom</from>
<to>Jack</to>
<heading>Remainders</heading>
<body> Dont'forget</body>
</note>
note.xsd : Defines element for note.xml
<?xml version="1.0"?>
<xs:schema xmlns:"http://www.w3.org/2001/XMLSchema" targetNameSpace="http://www.ayaz.com" xmlns="http://www.ayaz.com" elementFromDefault="qualified">
.
<xs:element name="note">
<xs:complexType>
<xs:sequence>
<xs:element name="to" type="xs:String"/>
<xs:element name="from" type="xs:String/>
<xs:element name="heading" type="xs:String/>
<xs:element name="body" type="xs:String/>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
We will look on each of the element in detail in later part.So i have the xsd for my xml element now i can refer in my Document .
<?xml version="1.0"?>
< note xmlns="http://www.ayaz.com" xmlns=xsi="http://www.w3org.2001/XMLSchema-instance"
xsi:schemaLocation="http://www.ayaz.com/note.xsd">
<from>Tom</from>
<to>Jack</to>
<heading>Remainders</heading>
<body> Dont'forget</body>
</note>
Red color highlighted - tells the Schema validator that all elements used in this XML Document are declared in "http://www.ayaz.com"
Blue color highlighted - tells once you have the XML Schema instances we can use the SchemaLocation Attribute.
Brown Color highlighted - tells the namespace used for the xsd and it's location.
2. XSD Elements:
XSD elements can be classified as "Single" and Complex" Element.
a.Simple Element :
A Simple element does not have any attribute and other elements.
It can contain only Text.The Text can be of any type (String,boolean,Int)or it can be custom type define by the user.
We can also add restrictions such as limit the content or to match the specific pattern.
Synatx:
<xs:element name="------ " type="------"/>
Ex: <xs:element name="firstname" type="xs:String"/>
Default & Fixed Value :
Default - This value is taken when there is no value is provided.
Fixed - This value is taken assigned automatically to the element and cannot assign other values.
Ex:
<xs:element name="firstname" type="xs:String" default="John "/>
<xs:element name="color" type="xs:String" fixed="red"/>
b. XSD Attributes:
Simple elements cannot have attributes. If an element is specified with attribute then it is considered ad complex type element.But a attribute always declared as simple type.
Synatx :
<xs:attribute name="-----" type="----"/>
Ex:
<xs:attribute name="lang" type="xs:String" />
<lastname lang="en">Smith</lastname> -- Refering in XML Document.
Note: Default and fixed behave same way as the does for simple element.
Optional & required
Attribute can be specify as optional or required one.Attributes are optional by default to make the attribute declared as required we should declared by the "use" keyword.
<xs:attribute name="lang" type="xs:String" use="required'/>
c. XSD Restrictions /Facets :
<xs:restriction> is used to set restrcitions.
Restriction on Simple Element
Ex: To accept values between 0-120
<xs:element name="age">
<xs:simpleType>
<xs:restriction base="xs:integer">
<xs:minInclusive value="0"/>
<xs:maxInclusive value="120"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
To set Restrictions on set of values use the enumeration
<xs:element name="car">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:enumeration value="Audi"/>
<xs:enumeration value="Golf"/>
<xs:enumeration value="BMW"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
Length Restriction
<xs:element name="password">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:length value="8"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
Constraint Description
enumeration | Defines a list of acceptable values |
fractionDigits | Specifies the maximum number of decimal places allowed. Must be equal to or greater than zero |
length | Specifies the exact number of characters or list items allowed. Must be equal to or greater than zero |
maxExclusive | Specifies the upper bounds for numeric values (the value must be less than this value) |
maxInclusive | Specifies the upper bounds for numeric values (the value must be less than or equal to this value) |
maxLength | Specifies the maximum number of characters or list items allowed. Must be equal to or greater than zero |
minExclusive | Specifies the lower bounds for numeric values (the value must be greater than this value) |
minInclusive | Specifies the lower bounds for numeric values (the value must be greater than or equal to this value) |
minLength | Specifies the minimum number of characters or list items allowed. Must be equal to or greater than zero |
pattern | Defines the exact sequence of characters that are acceptable |
totalDigits | Specifies the exact number of digits allowed. Must be greater than zero |
whiteSpace | Specifies how white space (line feeds, tabs, spaces, and carriage returns) is handled |
3. Complex XSD Elements :
A complex element is an XML element that contains other elements and/or attributes.
There are four kinds of complex elements:
- empty elements
- elements that contain only other elements
- elements that contain only text
- elements that contain both other elements and text.
An empty complex element cannot have contents, only attributes.
An empty XML element
<product prodid="1345" />
Ex:
<xs:element name="product">
<xs:complexType>
<xs:attribute name="prodid" type="xs:positiveInteger"/>
</xs:complexType>
</xs:element>
Element which have elements only :
An "elements-only" complex type contains an element that contains only other elements.
An XML element, "person", that contains only other elements:
<person>
<firstname>John</firstname>
<lastname>Smith</lastname>
</person>
<firstname>John</firstname>
<lastname>Smith</lastname>
</person>
You can define the "person" element in a schema, like this:
<xs:element name="person">
<xs:complexType>
<xs:sequence>
<xs:element name="firstname" type="xs:string"/>
<xs:element name="lastname" type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:complexType>
<xs:sequence>
<xs:element name="firstname" type="xs:string"/>
<xs:element name="lastname" type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
Text- Only :
A complex text-only element can contain text and attributes.
This type contains only simple content (text and attributes), therefore we add a simpleContent element around the content. When using simple content, you must define an extension OR a restriction within the simpleContent element, like this:
<xs:element name="somename">
<xs:complexType>
<xs:simpleContent>
....
....
</xs:extension>
</xs:simpleContent>
</xs:complexType>
</xs:element>
OR
<xs:element name="somename">
<xs:complexType>
<xs:simpleContent>
....
....
</xs:restriction>
</xs:simpleContent>
</xs:complexType>
</xs:element>
<xs:complexType>
<xs:simpleContent>
....
....
</xs:extension>
</xs:simpleContent>
</xs:complexType>
</xs:element>
OR
<xs:element name="somename">
<xs:complexType>
<xs:simpleContent>
....
....
</xs:restriction>
</xs:simpleContent>
</xs:complexType>
</xs:element>
Mixed Complex Elements:
A mixed complex type element can contain attributes, elements, and text.
An XML element, "letter", that contains both text and other elements:
<letter>
Dear Mr.<name>John Smith</name>.
Your order <orderid>1032</orderid>
will be shipped on 2001-07-13.
</letter>
Dear Mr.<name>John Smith</name>.
Your order <orderid>1032</orderid>
will be shipped on 2001-07-13.
</letter>
<xs:complexType mixed="true">
<xs:sequence>
<xs:element name="name" type="xs:string"/>
<xs:element name="orderid" type="xs:positiveInteger"/>
<xs:element name="shipdate" type="xs:date"/>
</xs:sequence>
</xs:complexType>
</xs:element>
4 . Indicators
There are seven indicators:
Order indicators:
- All
- Choice
- Sequence
- maxOccurs
- minOccurs
- Group name
- attributeGroup name
Mostly Used indicators are discussed below :
Sequence Indicator
The <sequence> indicator specifies that the child elements must appear in a specific order:
<xs:element name="person">
<xs:complexType>
<xs:sequence>
<xs:element name="firstname" type="xs:string"/>
<xs:element name="lastname" type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:complexType>
<xs:sequence>
<xs:element name="firstname" type="xs:string"/>
<xs:element name="lastname" type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
Occurence Indicator
Occurrence indicators are used to define how often an element can occur.
maxOccurs Indicator
The <maxOccurs> indicator specifies the maximum number of times an element can occur:
<xs:element name="person">
<xs:complexType>
<xs:sequence>
<xs:element name="full_name" type="xs:string"/>
<xs:element name="child_name" type="xs:string" maxOccurs="10"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:complexType>
<xs:sequence>
<xs:element name="full_name" type="xs:string"/>
<xs:element name="child_name" type="xs:string" maxOccurs="10"/>
</xs:sequence>
</xs:complexType>
</xs:element>
minOccurs Indicator
The <minOccurs> indicator specifies the minimum number of times an element can occur:
<xs:element name="person">
<xs:complexType>
<xs:sequence>
<xs:element name="full_name" type="xs:string"/>
<xs:element name="child_name" type="xs:string"
maxOccurs="10" minOccurs="0"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:complexType>
<xs:sequence>
<xs:element name="full_name" type="xs:string"/>
<xs:element name="child_name" type="xs:string"
maxOccurs="10" minOccurs="0"/>
</xs:sequence>
</xs:complexType>
</xs:element>
To allow an element to appear an unlimited number of times, use the maxOccurs="unbounded" statement
wsimport :
This tool is come along with the jdk.If you have install the JDK properly and your classpath or JAVA_HOME variable is set you can see the list of options provided by this command by typing wsimport in the command prompt.
For generating Java classess from wsimport the syntax is :
wsimport wsdl-location-path -d -keep
The wsdl-location-path : Is the location of wsdl file existence.
-d : specify the directory where all the generated classes should be placed.
-keep : It will keep the java source code of generated classes in the respective directory mentioned.
-extension :allow vendor extension - functionality if not have been specified.
Ex:
wsimport hello.wsdl src -keep
Now we will take the sample webservice of w3schools which has the follwing wsdl location:
http://www.w3schools.com/webservices/tempconvert.asmx?WSDL
Execute the command in DOS Prompt to generate classes from wsdl :
C:\webservice> wsimport http://www.w3schools.com/webservices/tempconvert.asmx?WSDL -extension -keep
After execution it will create a folder called org inside the webs service folder.
Now Create a Main class to access these webservice :
Code:
import org.tempuri.*;
public class Main {
public static void main(String a[])
{
TempConvert convert=new TempConvert();
System.out.println(convert.getTempConvertSoap().celsiusToFahrenheit("122"));
}
}
Save these class inside "webservice" folder .Compile and run it you will see the output as "251.6" returning from web service.
Result :
1.SOAP
2.REST
Here we will be creating SOAP based Web Service.What is SOAP and how it's work we have already seen,you can refer links in our index page. As per REST we will see in later part of our tutorials.
In this section we will concentrating on writing a Java webservice based upon a Java class which has a business method from this class a webservice we are going to create ,which can be access by many for there needs.
We are going to follow the eclipse Bottom approach to create this webservice.
Bottom-Up-Approach : It is used to create a webservice & WSDL from a Java class.
So before we begin we need the following
Requirements:
1. Eclipse IDE with J2EE Plugins or Eclipse Indigo J2EE Version [http://www.eclipse.org]
2.A Webserver or Application Server (Here i am using Tomcat Webserver)
Once we are done with our first webservice. We will access it through SOAP UI.We have already discuss about SOAPUI functionality in previous tutorials you can refer from here :
http://ayazroomy-java.blogspot.in/2013/07/java-web-service-tutorial-with-soap-ui.html
Now, Once you have the Eclipse IDE , You should configure the Tomcat Server in the Eclipse by Adding the Server in the Server TAB.So now we have the Server ready ....
Now create a new WebProject by :
Step 1:
File -> New -> Dynamic WebProject
Give a Name to the Project say : MyService and click the "Finish" Button.
Step 2:
Create a Package called "com.test" under "src" folder of "MyService" WebApplication.
Create a new Class called "Display" under "com.test" package.
Display class :
package com.test;
public class Display {
public String convert(String name)
{
return name.toUpperCase();
}
}
It is a straight forward simple class having a single business method which accepts a String and returns a String in Upper Case format.
Step 3:
Now, Right click on the Project "MyService"[Project Name] node and select the following :
New -> Other -> Webservices -> WebService : It will show a WebService Window
In this window we have couple of options:
1. Select the WebService Type as: BottomUp Java Bean Service
2. Select the class you have created now here namely : "Display By clicking on the Browse Button"
There are 3 Configuration links available in this window:
- ServerRuntime : Select your server in this case we have use Tomcat
- Service Runtime : Apache Axis - Default it will be selected
-Service Project : Specify your Project name here "MyService" and Click the Next Button >>
Step 4:
Follow instructions in screen shot below. Click Next Button ...
Step 5 :
After successful deployment the publishing window will appear.Now click the Finish Button
Now you can a wsdl namely Display.wsdl will be generated inside the wsdl folder under the WebContent Directory of the Project "MyService".
Display.wsdl :
<?xml version="1.0" encoding="UTF-8"?>
<wsdl:definitions targetNamespace="http://test.com" xmlns:apachesoap="http://xml.apache.org/xml-soap" xmlns:impl="http://test.com" xmlns:intf="http://test.com" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:wsdlsoap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<!--WSDL created by Apache Axis version: 1.4
Built on Apr 22, 2006 (06:55:48 PDT)-->
<wsdl:types>
<schema elementFormDefault="qualified" targetNamespace="http://test.com" xmlns="http://www.w3.org/2001/XMLSchema">
<element name="convert">
<complexType>
<sequence>
<element name="name" type="xsd:string"/>
</sequence>
</complexType>
</element>
<element name="convertResponse">
<complexType>
<sequence>
<element name="convertReturn" type="xsd:string"/>
</sequence>
</complexType>
</element>
</schema>
</wsdl:types>
<wsdl:message name="convertRequest">
<wsdl:part element="impl:convert" name="parameters">
</wsdl:part>
</wsdl:message>
<wsdl:message name="convertResponse">
<wsdl:part element="impl:convertResponse" name="parameters">
</wsdl:part>
</wsdl:message>
<wsdl:portType name="Display">
<wsdl:operation name="convert">
<wsdl:input message="impl:convertRequest" name="convertRequest">
</wsdl:input>
<wsdl:output message="impl:convertResponse" name="convertResponse">
</wsdl:output>
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name="DisplaySoapBinding" type="impl:Display">
<wsdlsoap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http"/>
<wsdl:operation name="convert">
<wsdlsoap:operation soapAction=""/>
<wsdl:input name="convertRequest">
<wsdlsoap:body use="literal"/>
</wsdl:input>
<wsdl:output name="convertResponse">
<wsdlsoap:body use="literal"/>
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name="DisplayService">
<wsdl:port binding="impl:DisplaySoapBinding" name="Display">
<wsdlsoap:address location="http://localhost:8080/MyService/services/Display"/>
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
Now in the browser if you type the URL :
http://localhost:8080/MyService/services . We can see list of Deployed Services in the Server.
Now, we have the service ready , now we can test this through SOAP UI.
Step 6:
- Open SOAP UI.
- Right Click on Project Node->New SoapUI Project --> Provide the WSDL Location Path .
- In this case http://localhost:8080/MyService/services/Display?wsdl
Open the Soap Request give some name in lower case in request XML and we can see the Response in Upper case for the given name.
We can create stub for this Webservice by using wsimport tool please refer http://ayazroomy-java.blogspot.in/2013/07/using-wsimport-tool-to-generate-client.html for creating Stub and client from WSDL.
Subscribe to:
Posts (Atom)