Writing simple Java
Web Services using
Eclipse
 Author:
 Santosh Kumar Kar
 santosh.bsil@yahoo.co.
 in
Create a new Project Wizard to create a project.
You need to select Dynamic Web Project so the deployment module can
be deployed in a server. If for you it does not appear, below there is a
checkbox [Show All Wizard], check in and then try.
Two important task here before you click the Finish button are:
1) Provide a project name for your web service application.
2) Put a server configuration under Target Runtime.
[NB: You cant see Apache Tomcat under the list unless Add project to an EAR
is disabled.]
A WSDL document defines services as collections of network
endpoints, or ports. In WSDL, the abstract definition of endpoints
and messages is separated from their concrete network
deployment or data format bindings. This allows the reuse of
abstract definitions: messages, which are abstract descriptions of
the data being exchanged, and port types which are abstract
collections of operations.
A WSDL document uses the following elements in the definition of
network services:
 Types: a container for data type definitions using some type
 system (such as XSD).
 Message: an abstract, typed definition of the data being
 communicated.
 Operation: an abstract description of an action supported by the
 service.
 Port Type: an abstract set of operations supported by one or
 more endpoints.
 Binding: a concrete protocol and data format specification for a
 particular port type. The binding is usually SOAP and the
 encoding and data formatting regulations used (also known as
 the style) is usually literal (this includes document/literal, and
 sometimes RPC/literal). Please refer
Web services can be created using two methods
 Top-down development
 Bottom-up development
Bottom-up strategy
In Bottom-up strategy, a developer writes java Beans or
enterprise beans. Then using the Web services wizard he creates
the WSDL file and Web service from those bean classes.
Top-down strategy
A developer using a top down method a developer first designs
the implementation of the Web service by creating a WSDL file.
You can use the WSDL Editor for this. Using the Web services
wizard you can create the Web service and skeleton Java
classes to which you can add the required code.
In this example, we are following the bottom-up strategy by
selecting Bottom up Java bean Web service in eclipse..
 1
 write your
 business
 implementation
methods for the
Server which can
 be invoked by a
Client program.
We are creating the class as RequesetHandler.java in
santosh.test.server package. Hope you know how to create a class in
the source folder (src).
We are writing 2 methods in the RequestHandler.java. Remember they
must be public.
1) taking a value and return its reverse.
2) get the current date in text format.
After writing the program, build the project to compile the class.
 2
 Generate the
WSDL for server.
You need to generate necessary files along with the wsdl. Eclipse takes
all the headache of creating the web service related files along with the
wsdl. Just you need to select the options provided in Eclipse. Follow the
steps.
Step 1: Build the application if not yet built. It will generate the .class
files.
Step 2: Right click on the RequstHandler.java, select web services ->
Create Web service
You will get a window where it will show you the default server provided
in Eclipse. You can use the one and just click on the Finish button.
But if you want to use the server as you have defined (we have used this
option to select the Apache Tomcat server in this tutorial),
 You need to choose the radio button Explore Options
 You can select the web service runtime either Apache Axis or IBM
 WebSphere JAX-RPC
 (We have selected Apache Axis here)
 For the Server, you can use the server under Server Types. Make sure
 you have choose the correct server else you will find the OK button
 disabled.
 Finally click on the OK Button
Right-click on RequestHandler.java, select Web Services->Create
Web service
Sometimes Eclipse comes along with embedded Application server, here
it is already with WebSphere 6.1. You may use the same server or you
can change your server.
To change your server or runtime, click on any of the above link marked
by Arrow. Select the radio button for Explore options (shown in next
After selecting the radio button to Explore option, we have seleted
 Under Web service runtime: Apache Axis
 Under Server: Tomcat v5.5 Server
Then click on OK button
Now you can see the configuration changed to Tomcat Server, Apache
Axis.
You can see the below files are newly generated. These are required for
the server in order to run the web service and deploy the module into
the web server container.
The most import file created here is the RequestHandler.wsdl
To read the files, you can double click on the below icons, open with
Notepad.
 deploy.wsdd undeploy.wsdd server-config.wsdd web.xml RequestHandler.wsdl
 Now you can deploy the WebServiceForServer.war into Tomcat. However,
 in Eclipse the module might already have deployed. If you want to
 deploy in another system/server, just export as war file and deploy in
 the server.
 How to ensure the deployment is successful???
 Answer is, run the below url as:
 http://localhost:8085/WebServiceForServer/services/RequestHandler?wsd
 l
 The webpage would appear as : see next page
 END
 OF
SERVE
 R
MODU
Beginn
ing OF
 Client
Module
Now we are going to write a very simple client
application. This is a standalone program, so when we
are creating project, I added only the project type as
Java Project. Follow the subsequent slides for the
steps.
Adding a name to my project WebServiceClient
This is a very import step to create the Client Stubs for the web service.
This will create
 Remote Interface used to call the business methods.
 Proxy class which is the intermediate between the client and the
 server.
 Service Locator class which contains the details of the server. This
 gets the Server Instance into the Client stub from Server.
 So for all these you need the .wsdl file created in the server. So just
 take the wsdl file from the server module and paste it into your client
 module. Here we copied the package wsdl from server to client. This
 contains the file RequestHandler.wsdl as shown in the image below.
 You need to generate all the above required for the client from this
 wsdl.
Right-click on the WSDL file, select Web Services->Generate Client.
Sometimes Eclipse comes along with embedded Application server, here
it is already with WebSphere 6.1. You may use the same server or you
can change your server.
To change your server or runtime, click on any of the above link marked
by Arrow. Select the radio button of Explore options. Please refer the
Select the radio button of Explore options. Select your server you
already configured. Here it is Tomcat v5.5 Server
Select the radio button of Explore options. Select your server you
already configured. Here it is Tomcat v5.5 Server. In package Explorer,
you can see now the created classes under package santosh.test.server
Now it is the time to write your client application to call the business
methods from Server. We created ServiceRequester under
santosh.test.client package.
Writing the client program is very easy as written for Server.
Only 3 steps you need to follow:
1. Find the locator class
2. Get the Handler
3. Call the service methods.
You can simply run the client program, the main() method will execute
and call the service methods.
You can see this presentation at
http://
javacompanionbysantosh.blogspot.co
m/
or
http://
www.slideshare.net/skkar2k2/writing-s
imple-web-services-using-eclipse-edit
or
 Send
 your
 queries
 to
santosh.bsil@gmail
.com