Home » Java » Enterprise Java » Getting started with JAX-WS

About Pavithra Siriwardena

Getting started with JAX-WS

JAX-WS stands for Java API for XML Web Services. It is a Java programming language API for creating web services and clients that communicate using XML. This post is a quick start for JAX-WS.


GlassFish integrated with Eclipse.

Creating the JAX-WS Web Service

1.In Eclipse create a Dynamic Web Project called ‘com.eviac.blog.jaxwsproj’. Make GlassFish as the Target Runtime.


2.Create a new class called ‘SampleWS’ in the created project. This will be the implementation class of the web service.


package com.eviac.blog.jaxws.service;

import javax.jws.WebMethod;
import javax.jws.WebService;

public class SampleWS {

 public int sum(int a, int b) {
  return a + b;

 public int multiply(int a, int b) {
  return a * b;


3.Open a terminal and navigate to the root of the project directory. Create a directory called wsdl inside WebContent/WEB-INF/. Use the following command to create web service artifacts. Make sure your JAVA_ HOME is set properly or this command will not work. Also make sure to build the project before running this command or it will complain class not found.

wsgen -classpath build/classes/ -wsdl -r WebContent/WEB-INF/wsdl -s src -d build/classes/ com.eviac.blog.jaxws.service.SampleWS

4.Refresh the project to discover created artifacts. Open the created WSDL-file inside wsdl folder. Search for REPLACE_WITH_ACTUAL_URL and replace it with the web service URL: http://localhost:8080/com.eviac.blog.jaxwsproj/SampleWSService, and save the file.

5.Deploy the project in Glassfish by right-clicking the project, click Run As -> Run on Server and select the Glassfish server.

Creating the JAX-WS client

1.Create a Java project in eclipse called ‘com.eviac.blog.jaxwsclientproj’. Open up a new terminal and go to the project root. Use the following command to generate the classes you need to access the web service. Here you will need to use the URL of the WSDL file.

wsimport -s src -d bin http://localhost:8080/com.eviac.blog.jaxwsproj/SampleWSService?wsdl

2.Create a new class called ‘SampleWSClient’ in the project.


package com.eviac.blog.jaxws.client;

import javax.xml.ws.WebServiceRef;

import com.eviac.blog.jaxws.service.SampleWS;
import com.eviac.blog.jaxws.service.SampleWSService;

public class SampleWSClient {

 @WebServiceRef(wsdlLocation = 'http://localhost:8080/com.eviac.blog.jaxwsproj/SampleWSService?wsdl')
 private static SampleWSService Samplews;

 public static void main(String[] args) {
  SampleWSClient wsClient = new SampleWSClient();

 public void run() {
  Samplews = new SampleWSService();
  SampleWS port = Samplews.getSampleWSPort();
  System.out.println('multiplication Result= '+ port.multiply(10, 20));
  System.out.println('Addition Result= '+port.sum(10, 20));


3.Right click on the project and click on Run As -> Java Application. This will result following.

multiplication Result= 200
Addition Result= 30

Reference: Getting started with JAX-WS from our JCG partner Pavithra Siriwardena at the EVIAC blog.

Do you want to know how to develop your skillset to become a Java Rockstar?

Subscribe to our newsletter to start Rocking right now!

To get you started we give you our best selling eBooks for FREE!

1. JPA Mini Book

2. JVM Troubleshooting Guide

3. JUnit Tutorial for Unit Testing

4. Java Annotations Tutorial

5. Java Interview Questions

6. Spring Interview Questions

7. Android UI Design

and many more ....


Leave a Reply

Your email address will not be published. Required fields are marked *


Want to take your Java Skills to the next level?
Grab our programming books for FREE!
  • Save time by leveraging our field-tested solutions to common problems.
  • The books cover a wide range of topics, from JPA and JUnit, to JMeter and Android.
  • Each book comes as a standalone guide (with source code provided), so that you use it as reference.
Last Step ...

Where should we send the free eBooks?

Good Work!
To download the books, please verify your email address by following the instructions found on the email we just sent you.