Module 2: Socket Programming: 8Cspl6241-Advanced Java Programming
Module 2: Socket Programming: 8Cspl6241-Advanced Java Programming
• java.net package
Session 10
• Java Networking is a concept of connecting two or more computing devices together so that we can share resources.
• Java socket programming provides facility to share data between different computing devices.
1.Sharing resources
2.Centralize software management
java.net package
1. TCP:
• Transmission Control Protocol provides reliable communication between the sender and receiver.
• TCP is used along with the Internet Protocol referred as TCP/IP.
2. UDP:
• User Datagram Protocol provides a connection-less protocol service by allowing packet of data to be transferred
along two or more nodes
Java Networking Terminology
Following are the widely used Java networking terminologies:
1. IP Address
2. Protocol
3. Port Number
4. MAC Address
5. Connection-oriented and connection-less protocol
6. Socket
1) IP Address
• IP address is a unique number assigned to a node of a network e.g. 192.168.0.1 . It is composed of octets that range
from 0 to 255.
• It is a logical address that can be changed.
2) Protocol
A protocol is a set of rules basically that is followed for communication. For example:
• TCP
• FTP
• Telnet
• SMTP
• POP etc.
3) Port Number
• The port number is used to uniquely identify different applications. It acts as a communication endpoint between
applications.
• The port number is associated with the IP address for communication between two applications.
4) MAC Address
• MAC (Media Access Control) address is a unique identifier of NIC (Network Interface Controller). A network node can
have multiple NIC but each with unique MAC address.
• For example, an ethernet card may have a MAC address of 00:0d:83::b1:c0:8e.
5) Connection-oriented and connection-less protocol
• In connection-oriented protocol:
• acknowledgement is sent by the receiver. So it is reliable but slow.
• Example : TCP.
• In connection-less protocol,
• acknowledgement is not sent by the receiver. So it is not reliable but fast.
• Example: UDP.
6) Socket
• A socket is an endpoint between two way communications.
java.net package
The java.net package is divided into two sections:
1. A Low-Level API:
• It deals with the abstractions of addresses i.e. networking identifiers, Sockets i.e. bidirectional data communication mechanism and
Interfaces i.e. network interfaces.
Following is the list of classes provided by java.net package to deal with networking applications in Java
• ContentHandlerFactory
• CookiePolicy
• CookieStore
• DatagramSocketImplFactory
• FileNameMap
• SocketOption<T>
• SocketOptions
• SocketImplFactory
• URLStreamHandlerFactory
• ProtocolFamily