0
SOCKET PROGRAMMING IN JAVA             Narendran Thangarajan,             @naren_live,             II Year, BE, CSE,      ...
What started it all.. Internet has emerged as a global ubiquitous  media for communication It has changed the way we liv...
Client Server Applications        The Web Service is provided by the server        and the clients use these services   Cl...
Sockets Introduced in BSD 4.1 UNIX 1981. Sockets are the endpoints of any  communication over the internet. Sockets are...
Why IP Address + Port number? • IP Address is of the form 10.0.0.1 • Port Number can be anything from 0 to 65,535.
Destination Socket = 10.0.0.2 : 80IP Address – Choose network                      20.0.0.0     10.0.0.0                  ...
Destination Socket = 10.0.0.2 : 80IP Address -> MAC Address – Locate the                          specific system         ...
Port Number – Process specificPort 10000                           Port 11000                         Port 120000
Understanding Ports         OutLook             AVGGmail               YM         Express            UpdatePort 1    Port ...
 Thus virtually, sockets are a connection  between the two processes in different  systems. Eg : Let the socket pairs be...
Networking Basics – the larger picture     Applications Layer       Standard apps         HTTP             TCP STACK   ...
Network Basics - Where are these sockets?      Applications Layer          Standard apps            HTTP              T...
Now into Socket programming..
Socket Programming with TCP Server starts first..   Server Process must be running first   Server must have created a s...
Client/Server Socket Interaction inTCP       Server     create socket,     port=x, for     incoming request:     welcomeSo...
Step 1 :                        Connection request            port   Server                                               ...
Types of Sockets in TCP ServerSocket – the socket used by servers Socket – Socket used by clients Create a ServerSocket...
The concept of Streams       Client output    Server input       stream           stream     Client              Server   ...
Socket Programming with UDP No Connection between client and server.   No handshaking   The sender has to explicitly me...
Client/server socket interaction:UDP   Server                   Client  create socket,       create socket,  port=x, for  ...
Coding time..
Conclusion Socket Programming is very easy in Java. Usually each and every socket is handled by a  separate thread in re...
Queries
Upcoming SlideShare
Loading in...5
×

Socket programming using java

4,895

Published on

Seminar on Socket Programming in Java including Hands-on Coding session.

Published in: Education, Technology
0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
4,895
On Slideshare
0
From Embeds
0
Number of Embeds
1
Actions
Shares
0
Downloads
99
Comments
0
Likes
0
Embeds 0
No embeds

No notes for slide

Transcript of "Socket programming using java"

  1. 1. SOCKET PROGRAMMING IN JAVA Narendran Thangarajan, @naren_live, II Year, BE, CSE, SSN College of Engg, Chennai.
  2. 2. What started it all.. Internet has emerged as a global ubiquitous media for communication It has changed the way we live, learn, enjoy, communicate, interact, engage, etc. To take advantage of this, businesses are ceaselessly trying to offer their services through the internet. So a huge demand for software developers good in creating internet-enabled applications.
  3. 3. Client Server Applications The Web Service is provided by the server and the clients use these services Client Server NetworkClient machine Server machine A client, where sockets and network This is A server, come in !!
  4. 4. Sockets Introduced in BSD 4.1 UNIX 1981. Sockets are the endpoints of any communication over the internet. Sockets are identified by socket addresses. Socket Address = IP Address + Port Number
  5. 5. Why IP Address + Port number? • IP Address is of the form 10.0.0.1 • Port Number can be anything from 0 to 65,535.
  6. 6. Destination Socket = 10.0.0.2 : 80IP Address – Choose network 20.0.0.0 10.0.0.0 30.0.0.0 40.0.0.0
  7. 7. Destination Socket = 10.0.0.2 : 80IP Address -> MAC Address – Locate the specific system 10.0.0.1 10.0.0.2
  8. 8. Port Number – Process specificPort 10000 Port 11000 Port 120000
  9. 9. Understanding Ports OutLook AVGGmail YM Express UpdatePort 1 Port 2 Port 3 Port 4 Transport Layer Packet Port num data Network layer
  10. 10.  Thus virtually, sockets are a connection between the two processes in different systems. Eg : Let the socket pairs be  10.0.0.1 : 80 and 20.0.0.1 : 2000  192.168.21.10 : 3000 and 192.168.100.1 : 6000
  11. 11. Networking Basics – the larger picture  Applications Layer  Standard apps  HTTP TCP STACK  FTP  Telnet Application  User apps (http,ftp,telnet,…)  Transport Layer Transport  TCP (TCP, UDP,..)  UDP Network  Network Layer (IP,..)  IP  Link Layer Link (device driver,..)  Device drivers
  12. 12. Network Basics - Where are these sockets?  Applications Layer  Standard apps  HTTP TCP STACK  FTP  Telnet Application  User apps (http,ftp,telnet,…)  Programming Interface: Sockets  SOCKETS Transport  Transport Layer (TCP, UDP,..)  TCP  UDP Network (IP,..)  Network Layer Link  IP  Link Layer (device driver,..)  Device drivers
  13. 13. Now into Socket programming..
  14. 14. Socket Programming with TCP Server starts first..  Server Process must be running first  Server must have created a socket which welcomes client’s connection. (Welcoming socket) Client contacts server by..  Creating Client local TCP socket  Specify IP Address and port number of server process.  When Client socket is created, the connection is established.  When connection is established, server creates a new socket (Connection Socket) to communicate with that client and the Welcoming socket is once again waiting for connections for other clients.
  15. 15. Client/Server Socket Interaction inTCP Server create socket, port=x, for incoming request: welcomeSocket = ServerSocket() Client wait for incoming TCP create socket, connection request connection setup connect to hostid, port=x connectionSocket = clientSocket = welcomeSocket.accept() Socket() send request using read request from clientSocket connectionSocket write reply to connectionSocket read reply from connectionSocket close connectionSocket close clientSocket
  16. 16. Step 1 : Connection request port Server ClientStep 2 : port Server port Client port Connection
  17. 17. Types of Sockets in TCP ServerSocket – the socket used by servers Socket – Socket used by clients Create a ServerSocket in the server and make it to wait for connections from Sockets from other clients
  18. 18. The concept of Streams Client output Server input stream stream Client Server socket socket Client input Server output stream stream
  19. 19. Socket Programming with UDP No Connection between client and server.  No handshaking  The sender has to explicitly mention the IP address and the port of the destination.  The server should extract the IP Address of the datagram everytime. Uses DatagramSocket.
  20. 20. Client/server socket interaction:UDP Server Client create socket, create socket, port=x, for clientSocket = incoming request: DatagramSocket() serverSocket = DatagramSocket() Create, address (hostid, port=x), send datagram request using clientSocket read request from serverSocket write reply to serverSocket read reply from specifying client clientSocket host address, port number close clientSocket
  21. 21. Coding time..
  22. 22. Conclusion Socket Programming is very easy in Java. Usually each and every socket is handled by a separate thread in real-time client/server environments.
  23. 23. Queries
  1. A particular slide catching your eye?

    Clipping is a handy way to collect important slides you want to go back to later.

×