Udp Socket Programming in Java – How to Code Client and Server

By | August 5, 2020

UDP - User Datagram Protocol sockets

UDP is an alternative protocol to the more commonly used TCP protocol. It is a connection-less protocol where you directly send packets without have to establish a proper connection.

UDP packets have smaller headers compared to TCP headers. Also data communication is faster since no acknowledgement is exchanged for reliable packet delivery.

In this quick tutorial we shall learn how to use udp sockets to make a simple client and server program.
UDP sockets can be used in java with the DatagramSocket class.

UDP Server

Let code a simple udp server that listens on a certain port number.

/**
	Java ECHO server with UDP sockets example
*/

import java.io.*;
import java.net.*;

public class udp_server
{
	public static void main(String args[])
	{
		DatagramSocket sock = null;
		
		try
		{
			//1. creating a server socket, parameter is local port number
			sock = new DatagramSocket(7777);
			
			//buffer to receive incoming data
			byte[] buffer = new byte[65536];
			DatagramPacket incoming = new DatagramPacket(buffer, buffer.length);
			
			//2. Wait for an incoming data
			echo("Server socket created. Waiting for incoming data...");
			
			//communication loop
			while(true)
			{
				sock.receive(incoming);
				byte[] data = incoming.getData();
				String s = new String(data, 0, incoming.getLength());
				
				//echo the details of incoming data - client ip : client port - client message
				echo(incoming.getAddress().getHostAddress() + " : " + incoming.getPort() + " - " + s);
				
				s = "OK : " + s;
				DatagramPacket dp = new DatagramPacket(s.getBytes() , s.getBytes().length , incoming.getAddress() , incoming.getPort());
				sock.send(dp);
			}
		}
		
		catch(IOException e)
		{
			System.err.println("IOException " + e);
		}
	}
	
	//simple function to echo data to terminal
	public static void echo(String msg)
	{
		System.out.println(msg);
	}
}

Run this program by typing the following at terminal/command line

$ javac udp_server.java && java udp_server
Server socket created. Waiting for incoming data...

Now the udp server is up and waiting for incoming data. To check that udp server is really up, the netstat command can be used.

On Linux

$ netstat -u -ap
(Not all processes could be identified, non-owned process info
 will not be shown, you would have to be root to see it all.)
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
udp        0      0 localhost:11211         *:*                                 -               
udp        0      0 localhost:48568         localhost:48568         ESTABLISHED -               
udp        0      0 localhost:domain        *:*                                 -               
udp        0      0 *:ipp                   *:*                                 -               
udp        0      0 *:17500                 *:*                                 4103/dropbox    
udp        0      0 *:mdns                  *:*                                 -               
udp        0      0 *:34271                 *:*                                 -               
udp6       0      0 [::]:43649              [::]:*                              -               
udp6       0      0 [::]:7777               [::]:*                              6277/java       
udp6       0      0 [::]:mdns               [::]:*                              -

Note the entry with local address "[::]:7777".
It is our java udp server. The output also shows the pid (6277) and the command name (java).

Now that our server is up and running, its time to connect to it and verify its working. To connect to a simple server like this a program like telnet is needed.

However the standard telnet utilities that ship with linux do not support udp. Hence we are going to use another utility called ncat. Ncat is a netcat implementation from nmap.

On ubuntu install nmap from synaptic shall also install ncat.

Quick example

$ ncat -vv localhost 7777 -u
Ncat: Version 5.21 ( http://nmap.org/ncat )
Ncat: Connected to 127.0.0.1:7777.

The ncat utility is now connected to our udp server. The 'vv' switch is for very verbose. It shows detailed information of what is going on. The 'u' option is for udp protocol.

Now that we are connected, its time to send some message to the server. Just type something and hit enter.

$ ncat -vv localhost 7777 -u
Ncat: Version 5.21 ( http://nmap.org/ncat )
Ncat: Connected to 127.0.0.1:7777.
hello
OK : hello
how are you
OK : how are you

Ok, so here we can see that the server replies with the same message with "OK : " prepended.
Multiple ncat terminals can connect to this udp server. Open another terminal and connect using the same command and try sending messages from both client terminals.

The server would reply to each. Since the concept of "connection" does not exist in udp, the same loop can handle multiple connections much like the select function of c socket library.

Now that we have tested our server, its time to write a client which shall be used in place of ncat.

UDP Client

Here is the code

/**
	Java ECHO client with UDP sockets example
*/

import java.io.*;
import java.net.*;

public class udp_client
{
	public static void main(String args[])
	{
		DatagramSocket sock = null;
		int port = 7777;
		String s;
		
		BufferedReader cin = new BufferedReader(new InputStreamReader(System.in));
		
		try
		{
			sock = new DatagramSocket();
			
			InetAddress host = InetAddress.getByName("localhost");
			
			while(true)
			{
				//take input and send the packet
				echo("Enter message to send : ");
				s = (String)cin.readLine();
				byte[] b = s.getBytes();
				
				DatagramPacket  dp = new DatagramPacket(b , b.length , host , port);
				sock.send(dp);
				
				//now receive reply
				//buffer to receive incoming data
				byte[] buffer = new byte[65536];
				DatagramPacket reply = new DatagramPacket(buffer, buffer.length);
				sock.receive(reply);
				
				byte[] data = reply.getData();
				s = new String(data, 0, reply.getLength());
				
				//echo the details of incoming data - client ip : client port - client message
				echo(reply.getAddress().getHostAddress() + " : " + reply.getPort() + " - " + s);
			}
		}
		
		catch(IOException e)
		{
			System.err.println("IOException " + e);
		}
	}
	
	//simple function to echo data to terminal
	public static void echo(String msg)
	{
		System.out.println(msg);
	}
}

Run the client

$ javac udp_client.java && java udp_client
Enter message to send : 
Hello
127.0.0.1 : 7777 - OK : Hello
Enter message to send : 
How are you
127.0.0.1 : 7777 - OK : How are you

Before running the client, make sure that the server is running in another terminal/console.
Whatever message the client sends, is send back with "OK : " added to it. The client the echoes the message onto the terminal.

So this completes the server and client communication using udp sockets.

Conclusion

If you are new to socket programming in Java then check out the previous post on socket programming basics:
Java socket programming Tutorial - How to code Client and Server

If you have any feedback or questions let us know in the comments below.

About Silver Moon

A Tech Enthusiast, Blogger, Linux Fan and a Software Developer. Writes about Computer hardware, Linux and Open Source software and coding in Python, Php and Javascript. He can be reached at [email protected].

12 Comments

Udp Socket Programming in Java – How to Code Client and Server
  1. Abdullah

    Getting error:
    Exception in thread “main” java.lang.NullPointerException
    at udp_client.main(udp_client.java:33)

Leave a Reply

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