Step 1: One time server

Size: px
Start display at page:

Download "Step 1: One time server"

Transcription

1 I seguenti codici saranno utili all instaurazione di una chat tra server e client, saranno presenti vari step, ognuno dei quali avrà delle caratteristiche differenti. Step 1: One time server Il programma permette a due pc di comunicare tra di loro utilizzando due programmi: un pc farà da client mentre l altro da server. Una volta avviati i programmi i due pc potranno comunicare tra di loro con una chat. La chat si chiuderà quando il client scriverà.bye. Server public class Server { private Socket socket = null; private ServerSocket server = null; private DataInputStream streamin = null; public Server(int port) { System.out.println("Binding to port " + port + ", please wait..."); server = new ServerSocket(port); System.out.println("Server started: " + server); System.out.println("Waiting for a client..."); socket = server.accept(); System.out.println("Client accepted: " + socket); open(); boolean done = false; while (!done) { String line = streamin.readutf(); System.out.println(line); done = line.equals(".bye"); { done = true; close(); { System.out.println(ioe); public void open() throws IOException { streamin = new DataInputStream(new BufferedInputStream(socket.getInputStream())); public void close() throws IOException

2 { if (socket!= null) socket.close(); if (streamin!= null) streamin.close(); public static void main(string args[]) { Server server = null; if (args.length!= 1) System.out.println("Usage: java Server port"); else server = new Server(Integer.parseInt(args[0])); Client public class Client { private Socket socket = null; private DataInputStream console = null; private DataOutputStream streamout = null; public Client(String servername, int serverport) { System.out.println("Establishing connection. Please wait..."); try { socket = new Socket(serverName, serverport); System.out.println("Connected: " + socket); start(); catch(unknownhostexception uhe) { System.out.println("Host unknown: " + uhe.getmessage()); { System.out.println("Unexpected exception: " + ioe.getmessage()); String line = ""; while (!line.equals(".bye")) { line = console.readline(); streamout.writeutf(line); streamout.flush(); { System.out.println("Sending error: " + ioe.getmessage()); public void start() throws IOException { console = new DataInputStream(System.in); streamout = new DataOutputStream(socket.getOutputStream());

3 public void stop() { if (console!= null) console.close(); if (streamout!= null) streamout.close(); if (socket!= null) socket.close(); { System.out.println("Error closing..."); public static void main(string args[]) { Client client = null; if (args.length!= 2) System.out.println("Usage: java Client host port"); else client = new Client(args[0], Integer.parseInt(args[1])); Step 2: Many time server, one client Lo Step 2 è simile al primo, infatti il client rimarrà lo stesso; a cambiare è il server in quanto sarà in grado di rimanere aperto alla connessione anche dopo che il client sarà uscito (utilizzando sempre il comando.bye). Il server può infatti supportare più connessioni da parte del client durante la sua vita. Server public class Server implements Runnable { private Socket socket = null; private ServerSocket server = null; private Thread thread = null; private DataInputStream streamin = null; public Server(int port) { System.out.println("Binding to port " + port + ", please wait..."); server = new ServerSocket(port); System.out.println("Server started: " + server); start(); { System.out.println(ioe); public void run() { while (thread!= null)

4 { System.out.println("Waiting for a client..."); socket = server.accept(); System.out.println("Client accepted: " + socket); open(); boolean done = false; while (!done) { String line = streamin.readutf(); System.out.println(line); done = line.equals(".bye"); { done = true; close(); catch(ioexception ie) { System.out.println("Acceptance Error: " + ie); public void start() { if (thread == null) { thread = new Thread(this); thread.start(); public void stop() { if (thread!= null) { thread.stop(); thread = null; public void open() throws IOException { streamin = new DataInputStream(new BufferedInputStream(socket.getInputStream())); public void close() throws IOException { if (socket!= null) socket.close(); if (streamin!= null) streamin.close(); public static void main(string args[]) { Server server = null; if (args.length!= 1) System.out.println("Usage: java Server port"); else server = new Server(Integer.parseInt(args[0]));

5 Step 3: Multi server handling, multi client Anche su questo step il client sarà lo stesso degli step precedenti; Il server sarà anche qui diverso, verranno infatti implementati i thread attraverso la classe ServerThread che avrà il comando extends Thread. A differenza dello step precedente il server potrà supportare più client alla volta.

6 Server public class Server implements Runnable { private ServerSocket server = null;

7 private Thread thread = null; private ServerThread client = null; public Server(int port) { System.out.println("Binding to port " + port + ", please wait..."); server = new ServerSocket(port); System.out.println("Server started: " + server); start(); { System.out.println(ioe); public void run() { while (thread!= null) { System.out.println("Waiting for a client..."); addthread(server.accept()); catch(ioexception ie) { System.out.println("Acceptance Error: " + ie); public void addthread(socket socket) { System.out.println("Client accepted: " + socket); client = new ServerThread(this, socket); try { client.open(); client.start(); { System.out.println("Error opening thread: " + ioe); public void start() { /* no change */ public void stop() { /* no change */ public static void main(string args[]){ /* no change */ public class ServerThread extends Thread { private Socket socket = null; private Server server = null; private int ID = -1; private DataInputStream streamin = null; public ServerThread(Server _server, Socket _socket) { server = _server; socket = _socket; ID = socket.getport();

8 public void run() { System.out.println("Server Thread " + ID + " running."); while (true) { System.out.println(streamIn.readUTF()); { public void open() throws IOException { streamin = new DataInputStream(new BufferedInputStream(socket.getInputStream())); public void close() throws IOException { if (socket!= null) socket.close(); if (streamin!= null) streamin.close(); Step 4: A simple but functional, text based chat server/client Lo step 4 avrà anch esso i thread, sia per il server che per il client: ci saranno infatti 4 classi, Server e ServerThread, Client e ClientThread. Come per lo step precedente il server permette la connessione di più client alla votla, ma quando o il server o un client riceveranno un messaggio, lo invieranno anche a tutti gli altri client.

9 Server public class Server implements Runnable { private ServerThread clients[] = new ServerThread[50]; private ServerSocket server = null; private Thread thread = null; private int clientcount = 0; public Server(int port) { System.out.println("Binding to port " + port + ", please wait..."); server = new ServerSocket(port); System.out.println("Server started: " + server);

10 start(); { System.out.println("Can not bind to port " + port + ": " + ioe.getmessage()); public void run() { while (thread!= null) { System.out.println("Waiting for a client..."); addthread(server.accept()); { System.out.println("Server accept error: " + ioe); stop(); public void start() { /* as before */ public void stop() { /* as before */ private int findclient(int ID) { for (int i = 0; i < clientcount; i++) if (clients[i].getid() == ID) return i; return -1; public synchronized void handle(int ID, String input) { if (input.equals(".bye")) { clients[findclient(id)].send(".bye"); remove(id); else for (int i = 0; i < clientcount; i++) clients[i].send(id + ": " + input); public synchronized void remove(int ID) { int pos = findclient(id); if (pos >= 0) { ServerThread toterminate = clients[pos]; System.out.println("Removing client thread " + ID + " at " + pos); if (pos < clientcount-1) for (int i = pos+1; i < clientcount; i++) clients[i-1] = clients[i]; clientcount--; try { toterminate.close(); { System.out.println("Error closing thread: " + ioe); toterminate.stop(); private void addthread(socket socket) { if (clientcount < clients.length) { System.out.println("Client accepted: " + socket); clients[clientcount] = new ServerThread(this, socket); try { clients[clientcount].open(); clients[clientcount].start();

11 clientcount++; { System.out.println("Error opening thread: " + ioe); else System.out.println("Client refused: maximum " + clients.length + " reached."); public static void main(string args[]) { /* as before */ public class ServerThread extends Thread { private Server server = null; private Socket socket = null; private int ID = -1; private DataInputStream streamin = null; private DataOutputStream streamout = null; public ServerThread(Server _server, Socket _socket) { super(); server = _server; socket = _socket; ID = socket.getport(); public void send(string msg) { streamout.writeutf(msg); streamout.flush(); { System.out.println(ID + " ERROR sending: " + ioe.getmessage()); server.remove(id); stop(); public int getid() { return ID; public void run() { System.out.println("Server Thread " + ID + " running."); while (true) { server.handle(id, streamin.readutf()); { System.out.println(ID + " ERROR reading: " + ioe.getmessage()); server.remove(id); stop();

12 public void open() throws IOException { streamin = new DataInputStream(new BufferedInputStream(socket.getInputStream())); streamout = new DataOutputStream(new BufferedOutputStream(socket.getOutputStream())); public void close() throws IOException { if (socket!= null) socket.close(); if (streamin!= null) streamin.close(); if (streamout!= null) streamout.close(); Client public class Client implements Runnable { private Socket socket = null; private Thread thread = null; private DataInputStream console = null; private DataOutputStream streamout = null; private ClientThread client = null; public Client(String servername, int serverport) { System.out.println("Establishing connection. Please wait..."); try { socket = new Socket(serverName, serverport); System.out.println("Connected: " + socket); start(); catch(unknownhostexception uhe) { System.out.println("Host unknown: " + uhe.getmessage()); { System.out.println("Unexpected exception: " + ioe.getmessage()); public void run() { while (thread!= null) { streamout.writeutf(console.readline()); streamout.flush(); { System.out.println("Sending error: " + ioe.getmessage()); stop(); public void handle(string msg)

13 { if (msg.equals(".bye")) { System.out.println("Good bye. Press RETURN to exit..."); stop(); else System.out.println(msg); public void start() throws IOException { console = new DataInputStream(System.in); streamout = new DataOutputStream(socket.getOutputStream()); if (thread == null) { client = new ClientThread(this, socket); thread = new Thread(this); thread.start(); public void stop() { if (thread!= null) { thread.stop(); thread = null; try { if (console!= null) console.close(); if (streamout!= null) streamout.close(); if (socket!= null) socket.close(); { System.out.println("Error closing..."); client.close(); client.stop(); public static void main(string args[]) { Client client = null; if (args.length!= 2) System.out.println("Usage: java Client host port"); else client = new Client(args[0], Integer.parseInt(args[1])); public class ClientThread extends Thread { private Socket socket = null; private Client client = null; private DataInputStream streamin = null; public ClientThread(Client _client, Socket _socket) { client = _client;

14 socket = _socket; open(); start(); public void open() { streamin = new DataInputStream(socket.getInputStream()); { System.out.println("Error getting input stream: " + ioe); client.stop(); public void close() { if (streamin!= null) streamin.close(); { System.out.println("Error closing input stream: " + ioe); public void run() { while (true) { client.handle(streamin.readutf()); { System.out.println("Listening error: " + ioe.getmessage()); client.stop(); Step 5: client moved to very simple GUI interface Lo step 5 funzionerà identico allo step 4, ma il tutto funzionerà attraverso un interfaccia grafica. Client import java.applet.*; import java.awt.*; public class Client extends Applet { private Socket socket = null; private DataInputStream console = null; private DataOutputStream streamout = null; private ClientThread client = null;

15 private TextArea display = new TextArea(); private TextField input = new TextField(); private Button send = new Button("Send"), connect = new Button("Connect"), quit = new Button("Bye"); private String servername = "localhost"; private int serverport = 4444; public void init() { Panel keys = new Panel(); keys.setlayout(new GridLayout(1,2)); keys.add(quit); keys.add(connect); Panel south = new Panel(); south.setlayout(new BorderLayout()); south.add("west", keys); south.add("center", input); south.add("east", send); Label title = new Label("Simple Client Applet", Label.CENTER); title.setfont(new Font("Helvetica", Font.BOLD, 14)); setlayout(new BorderLayout()); add("north", title); add("center", display); add("south", south); quit.disable(); send.disable(); getparameters(); public boolean action(event e, Object o) { if (e.target == quit) { input.settext(".bye"); send(); quit.disable(); send.disable(); connect.enable(); else if (e.target == connect) { connect(servername, serverport); else if (e.target == send) { send(); input.requestfocus(); return true; public void connect(string servername, int serverport) { println("establishing connection. Please wait..."); try { socket = new Socket(serverName, serverport); println("connected: " + socket); open(); send.enable(); connect.disable(); quit.enable(); catch(unknownhostexception uhe) { println("host unknown: " + uhe.getmessage()); { println("unexpected exception: " + ioe.getmessage()); private void send() { streamout.writeutf(input.gettext()); streamout.flush(); input.settext(""); { println("sending error: " + ioe.getmessage()); close(); public void handle(string msg) { if (msg.equals(".bye")) { println("good bye. Press RETURN to exit..."); close(); else println(msg); public void open() { streamout = new DataOutputStream(socket.getOutputStream()); client = new ClientThread(this, socket); { println("error opening output stream: " + ioe);

16 public void close() { if (streamout!= null) streamout.close(); if (socket!= null) socket.close(); { println("error closing..."); client.close(); client.stop(); private void println(string msg) { display.appendtext(msg + "\n"); public void getparameters() { servername = getparameter("host"); serverport = Integer.parseInt(getParameter("port"));

830512@itri.org.tw import java.net.socket; import java.net.serversocket; import java.io.ioexception; /* ---------- Java Server ---------- */ public class Nets static Socket thesocket; static ServerThread

More information

Principles, Models, and Applications for Distributed Systems M

Principles, Models, and Applications for Distributed Systems M Università degli Studi di Bologna Facoltà di Ingegneria Principles, Models, and Applications for Distributed Systems M Lab assignment 4 (worked-out) Connection-oriented Java Sockets Luca Foschini Winter

More information

Principles, Models, and Applications for Distributed Systems M

Principles, Models, and Applications for Distributed Systems M Università degli Studi di Bologna Facoltà di Ingegneria Principles, Models, and Applications for Distributed Systems M Exercitation 3 Connected Java Sockets Jacopo De Benedetto Distributed architecture

More information

PROGRAMMAZIONE AVANZATA JAVA E C

PROGRAMMAZIONE AVANZATA JAVA E C PROGRAMMAZIONE AVANZATA JAVA E C Massimiliano Redolfi Lezione 12: networks with Java TCP vs UDP https://docs.oracle.com/javase/tutorial/networking/overview/networking.html TCP vs UDP TCP (Transmission

More information

Programmi di utilità

Programmi di utilità Programmi di utilità La classe SystemData per il calcolo dei tempi e della occupazione di memoria Per calcolare i tempi e la occupazione di memoria è necessario interagire con il sistema operativo, questo

More information

public static void main(string[] args) throws IOException { sock = new Socket(args[0], Integer.parseInt(args[1]));

public static void main(string[] args) throws IOException { sock = new Socket(args[0], Integer.parseInt(args[1])); Echo Client&Server Application EchoClient import java.net.*; import java.io.*; class EchoClient public static void main(string[] args) throws IOException if (args.length < 2) number>"); System.err.println("Usage:

More information

JAVA - NETWORKING (SOCKET PROGRAMMING)

JAVA - NETWORKING (SOCKET PROGRAMMING) JAVA - NETWORKING (SOCKET PROGRAMMING) http://www.tutorialspoint.com/java/java_networking.htm Copyright tutorialspoint.com The term network programming refers to writing programs that execute across multiple

More information

WINDOWS SOCKET PROGRAMMING

WINDOWS SOCKET PROGRAMMING WINDOWS SOCKET PROGRAMMING Headers and libraries All the declarations are in one header, winsock.h Your socket programs must link to the Winsock library (usually called wsock32.lib or winsock32.lib) Initialization

More information

Networking Code CSCI 201 Principles of Software Development

Networking Code CSCI 201 Principles of Software Development Networking Code CSCI 201 Principles of Software Development Jeffrey Miller, Ph.D. jeffrey.miller@usc.edu Server Networking Client Networking Program Outline USC CSCI 201L Server Software A server application

More information

Object-Oriented Programming in Java

Object-Oriented Programming in Java CSCI/CMPE 3326 Object-Oriented Programming in Java 1. Socket Programming Dongchul Kim Department of Computer Science University of Texas Rio Grande Valley Two types of TCP Socket java.net.serversocket

More information

A socket is a software endpoint that establishes bidirectional communication between a server program and one or more client programs.

A socket is a software endpoint that establishes bidirectional communication between a server program and one or more client programs. PART 24 Java Network Applications 24.1 Java Socket Programming A socket is a software endpoint that establishes bidirectional communication between a server program and one or more client programs. A server

More information

TCP and UDP Socket Programming in JAVA TCP Socket Programming 1. Write code for Client and save in GreetingClient.java

TCP and UDP Socket Programming in JAVA TCP Socket Programming 1. Write code for Client and save in GreetingClient.java TCP Socket Programming 1. Write code for Client and save in GreetingClient.java // File Name GreetingClient.java public class GreetingClient public static void main(string [] args) String servername =

More information

CS2307 NETWORKS LAB 1. Programs using TCP Sockets (like date and time server & client, echo server & client, etc.) 2. Programs using UDP Sockets

CS2307 NETWORKS LAB 1. Programs using TCP Sockets (like date and time server & client, echo server & client, etc.) 2. Programs using UDP Sockets CS2307 NETWORKS LAB 1. Programs using TCP Sockets (like date and time server & client, echo server & client, etc.) 2. Programs using UDP Sockets (like simple DNS) 3. Programs using Raw sockets (like packet

More information

Threads in Java (Deitel & Deitel)

Threads in Java (Deitel & Deitel) Threads in Java (Deitel & Deitel) OOutline 1 Introduction 1 Class Thread: An Overview of the Thread Methods 1 Thread States: Life Cycle of a Thread 1 Thread Priorities and Thread Scheduling 1 Thread Synchronization

More information

Principles, Models and Applications for Distributed Systems M

Principles, Models and Applications for Distributed Systems M Università degli Studi di Bologna Facoltà di Ingegneria Principles, Models and Applications for Distributed Systems M Lab assignment 2 (worked-out) Connectionless Java Sockets Luca Foschini 2010/2011 Exercise

More information

Java Networking (sockets)

Java Networking (sockets) Java Networking (sockets) Rui Moreira Links: http://java.sun.com/docs/books/tutorial/networking/toc.html#sockets http://www.javaworld.com/javaworld/jw-12-1996/jw-12-sockets_p.html Networking Computers

More information

Reading from URL. Intent - open URL get an input stream on the connection, and read from the input stream.

Reading from URL. Intent - open URL  get an input stream on the connection, and read from the input stream. Simple Networking Loading applets from the network. Applets are referenced in a HTML file. Java programs can use URLs to connect to and retrieve information over the network. Uniform Resource Locator (URL)

More information

agentmom User's Manual

agentmom User's Manual July 2000 agentmom User's Manual Scott A. DeLoach GRADUATE SCHOOL OF ENGINEERING AND MANAGEMENT AIR FORCE INSTITUTE OF TECHNOLOGY WRIGHT-PATTERSON AIR FORCE BASE, OHIO Approved for public release; distribution

More information

Internet Technology 2/7/2013

Internet Technology 2/7/2013 Sample Client-Server Program Internet Technology 02r. Programming with Sockets Paul Krzyzanowski Rutgers University Spring 2013 To illustrate programming with TCP/IP sockets, we ll write a small client-server

More information

URL Kullanımı Get URL

URL Kullanımı Get URL Networking 1 URL Kullanımı Get URL URL info 2 import java.io.*; import java.net.*; public class GetURL { public static void main(string[] args) { InputStream in = null; OutputStream out = null; // Check

More information

Connecting to a Server Implementing Servers Making URL Connections Advanced Socket Programming

Connecting to a Server Implementing Servers Making URL Connections Advanced Socket Programming Course Name: Advanced Java Lecture 11 Topics to be covered Connecting to a Server Implementing Servers Making URL Connections Advanced Socket Programming Introduction Internet and WWW have emerged as global

More information

Fondamenti di Informatica C. Lezione 24: Dentro le applet

Fondamenti di Informatica C. Lezione 24: Dentro le applet Fondamenti di Informatica C Lezione 24: Dentro le applet 22-11-2004 Il commento iniziale /* --------------------------------------------------- This applet creates a few different user interface components

More information

CPSC 441 Tutorial TCP Server. Department of Computer Science University of Calgary

CPSC 441 Tutorial TCP Server. Department of Computer Science University of Calgary CPSC 441 Tutorial TCP Server Department of Computer Science University of Calgary TCP Socket Client Server Connection Request Server Listening on welcoming socket Client Socket Server Socket Data Simple

More information

World Scientific Research Journal (WSRJ) ISSN: The Implementation of Tcp Socket Programming based on Java

World Scientific Research Journal (WSRJ) ISSN: The Implementation of Tcp Socket Programming based on Java World Scientific Research Journal (WSRJ) ISSN: 2472-3703 www.wsr-j.org The Implementation of Tcp Socket Programming based on Java Deen Chen Computer Science Department, North China Electric Power University,

More information

Week 12. Streams and File I/O. Overview of Streams and File I/O Text File I/O

Week 12. Streams and File I/O. Overview of Streams and File I/O Text File I/O Week 12 Streams and File I/O Overview of Streams and File I/O Text File I/O 1 I/O Overview I/O = Input/Output In this context it is input to and output from programs Input can be from keyboard or a file

More information

ICOM 4015-Advanced Programming. Spring Instructor: Dr. Amir H. Chinaei. TAs: Hector Franqui, Jose Garcia, and Antonio Tapia. Reference: Big Java

ICOM 4015-Advanced Programming. Spring Instructor: Dr. Amir H. Chinaei. TAs: Hector Franqui, Jose Garcia, and Antonio Tapia. Reference: Big Java ICOM 4015-Advanced Programming Spring 2014 Instructor: Dr. Amir H. Chinaei TAs: Hector Franqui, Jose Garcia, and Antonio Tapia Reference: Big Java By Hortsmann, Ed 4 Lab 7 Continuation of HTTP and Introduction

More information

Chapter 3: A Larger Example: SocketChat

Chapter 3: A Larger Example: SocketChat page 1 Chapter 3: A Larger Example: SocketChat In this chapter we are going to look at three versions of a larger socket-based example: a simple `chat' application. The application does not have many capabilities,

More information

Lösningsförslag till tentamen

Lösningsförslag till tentamen till tentamen 1 (5) Kursnamn Objektorienterade applikationer Tentamensdatum 2018-08-27 Program DAI 2 Läsår 2017/2018, lp 3 Examinator Uno Holmer Uppgift 1 (6 p) Detta diagram är ett exempel på designmönstret

More information

COMP 213. Advanced Object-oriented Programming. Lecture 19. Input/Output

COMP 213. Advanced Object-oriented Programming. Lecture 19. Input/Output COMP 213 Advanced Object-oriented Programming Lecture 19 Input/Output Input and Output A program that read no input and produced no output would be a very uninteresting and useless thing. Forms of input/output

More information

Week 13 Lab - Exploring Connections & Remote Execution

Week 13 Lab - Exploring Connections & Remote Execution Week 13 Lab - Exploring Connections & Remote Execution COSC244 & TELE202 1 Assessment This lab is worth 0.5%. The marks are awarded for completing the programming exercise and answering the questions.

More information

Java Support for developing TCP Network Based Programs

Java Support for developing TCP Network Based Programs Java Support for developing TCP Network Based Programs 1 How to Write a Network Based Program (In Java) As mentioned, we will use the TCP Transport Protocol. To communicate over TCP, a client program and

More information

User Data Protocol (2)

User Data Protocol (2) User Data Protocol (2) cosa succede se un altro processo fa la... send quando questo processo e' nella sleep? Thread.sleep(100000); so = new DatagramSocket(porta); so.receive(pacric); catch... ... so =

More information

Transmission Control Protocol

Transmission Control Protocol Transmission Control Protocol Descrizione livelli TCP/IP fisico: hardware e protocollo scheda di rete rete: protocollo IP trasporto: protocolli TCP e UDP applicazione: telnet, ssh, i vostri programmi Protocollo

More information

Java for Interfaces and Networks (DT3010, HT11)

Java for Interfaces and Networks (DT3010, HT11) Java for Interfaces and Networks (DT3010, HT11) Networking with Threads and Federico Pecora School of Science and Technology Örebro University federico.pecora@oru.se Federico Pecora Java for Interfaces

More information

Distributed Systems. 3. Access to the Transport Layer. Werner Nutt

Distributed Systems. 3. Access to the Transport Layer. Werner Nutt Distributed Systems 3. Access to the Transport Layer Werner Nutt 1 Access to the Transport Layer Processes issue requests to the transport layer (i.e., the application takes the initiative, not the transport

More information

Java for Interfaces and Networks (DT3029)

Java for Interfaces and Networks (DT3029) Java for Interfaces and Networks (DT3029) Lecture 4 Networking with Threads and Containers Federico Pecora federico.pecora@oru.se Center for Applied Autonomous Sensor Systems (AASS) Örebro University,

More information

Steps for Implementing a Server

Steps for Implementing a Server Agenda 5 Steps for creating a server 1. Create a ServerSocket object 2. Create a Socket object from ServerSocket 3. Create an input stream 4. Create an output stream 5. Do I/O with input and output streams

More information

CSE 660 Lab 7. Submitted by: Arumugam Thendramil Pavai. 1)Simple Remote Calculator. Server is created using ServerSocket class of java. Server.

CSE 660 Lab 7. Submitted by: Arumugam Thendramil Pavai. 1)Simple Remote Calculator. Server is created using ServerSocket class of java. Server. CSE 660 Lab 7 Submitted by: Arumugam Thendramil Pavai 1)Simple Remote Calculator Server is created using ServerSocket class of java Server.java import java.io.ioexception; import java.net.serversocket;

More information

Implementazione Java di Alberi Binari. A.A. 16/17 DA1 - Andrea Pietracaprina 1

Implementazione Java di Alberi Binari. A.A. 16/17 DA1 - Andrea Pietracaprina 1 Implementazione Java di Alberi Binari A.A. 16/17 DA1 - Andrea Pietracaprina 1 Idea: struttura linkata Un nodo contiene Element Parent node Left child node Right child node B B A D A D C E C E A.A. 16/17

More information

Networking with java (socket programming) a brief study

Networking with java (socket programming) a brief study REVIEWS COMPUTER ENGINEERING Discovery Engineering, Volume 2, Number 7, October 2013 ISSN 2320 6675 EISSN 2320 6853 Discovery Engineering REVIEWS COMPUTER ENGINEERING discovery Engineering Networking with

More information

Network Programming: Servers

Network Programming: Servers 2012 Marty Hall Network Programming: Servers Originals of Slides and Source Code for Examples: http://courses.coreservlets.com/course-materials/java.html 3 Customized Java EE Training: http://courses.coreservlets.com/

More information

Java for Interfaces and Networks

Java for Interfaces and Networks Java for Interfaces and Networks Threads and Networking Federico Pecora School of Science and Technology Örebro University federico.pecora@oru.se Federico Pecora Java for Interfaces and Networks Lecture

More information

CONCURRENCY IN JAVA Course Parallel Computing

CONCURRENCY IN JAVA Course Parallel Computing CONCURRENCY IN JAVA Course Parallel Computing Wolfgang Schreiner Research Institute for Symbolic Computation (RISC) Wolfgang.Schreiner@risc.jku.at http://www.risc.jku.at Java on a NUMA Architecture Loading

More information

CS September 2017

CS September 2017 Machine vs. transport endpoints IP is a network layer protocol: packets address only the machine IP header identifies source IP address, destination IP address Distributed Systems 01r. Sockets Programming

More information

B2.52-R3: INTRODUCTION TO OBJECT-ORIENTED PROGRAMMING THROUGH JAVA

B2.52-R3: INTRODUCTION TO OBJECT-ORIENTED PROGRAMMING THROUGH JAVA B2.52-R3: INTRODUCTION TO OBJECT-ORIENTED PROGRAMMING THROUGH JAVA NOTE: 1. There are TWO PARTS in this Module/Paper. PART ONE contains FOUR questions and PART TWO contains FIVE questions. 2. PART ONE

More information

Apéndice A. Código fuente de aplicación desarrollada para probar. implementación de IPv6

Apéndice A. Código fuente de aplicación desarrollada para probar. implementación de IPv6 Apéndice A Código fuente de aplicación desarrollada para probar implementación de IPv6 import java.awt.*; import java.awt.event.*; import javax.swing.*; import java.io.*; import java.net.*; import java.util.enumeration;

More information

CS 351 Week Advanced UNIX Programming: Rochkind, Marc J. 1. To learn about System Interprocess Communication (IPC). 2. To learn about Sockets.

CS 351 Week Advanced UNIX Programming: Rochkind, Marc J. 1. To learn about System Interprocess Communication (IPC). 2. To learn about Sockets. CS 351 Week 11 Reading: 1. Advanced UNIX Programming: Rochkind, Marc J. Objectives: 1. To learn about System Interprocess Communication (IPC). 2. To learn about Sockets. Concepts: 1. Interprocess Communication

More information

MOC10215 Implementing and Managing Server Virtualization

MOC10215 Implementing and Managing Server Virtualization Tel. +39 02 365738 info@overneteducation.it www.overneteducation.it MOC10215 Implementing and Managing Server Virtualization Durata: 4.5 gg Descrizione Questo corso fornisce le competenze e le conoscenze

More information

JAVA 프로그래밍 II. Lab #7 (Networking) TCP Java Socket. TCP vs UDP 2017 학년도 1 학기 년봄학기 5/24/2017 박경신. Client. Server

JAVA 프로그래밍 II. Lab #7 (Networking) TCP Java Socket. TCP vs UDP 2017 학년도 1 학기 년봄학기 5/24/2017 박경신. Client. Server Lab #7 (Networking) 2017 학년도 1 학기 JAVA 프로그래밍 II 기존요구사항분석 Lab #6 는 Thread, Runnable 과 SwingWorker 를이용한다양한멀티스레드기능을사용 Lab #7 는 TCP/UDP 등다양한네트워크프로그래밍기능을사용 TCP, UDP, HTTP, File Transfer 514770-1 2017 년봄학기 5/24/2017

More information

MOC20741 Networking with Windows Server 2016

MOC20741 Networking with Windows Server 2016 Tel. +39 02 365738 info@overneteducation.it www.overneteducation.it MOC20741 Networking with Windows Server 2016 Durata: 4.5 gg Descrizione Questo corso intende trasmettere le competenze fondamentali in

More information

MYcsvtu Notes. Experiment-1. AIM: Write a program to implement fiestal cipher structure PROGRAM: import java.io.*; class functions

MYcsvtu Notes. Experiment-1. AIM: Write a program to implement fiestal cipher structure PROGRAM: import java.io.*; class functions Experiment-1 AIM: Write a program to implement fiestal cipher structure PROGRAM: import java.io.*; class functions String Xor(String s1,string s2) char s1array[]=s1.tochararray(); char s2array[]=s2.tochararray();

More information

Multi-threaded Web Server (Assignment 1) Georgios Georgiadis

Multi-threaded Web Server (Assignment 1) Georgios Georgiadis Multi-threaded Web Server (Assignment 1) Georgios Georgiadis Overview Multi-threaded Web Server What to do and how to do it HTTP messages Processes and threads ComputerComm '09 2 Multi-threaded Web Server

More information

MSQ3-8 - MOC UPDATING YOUR SQL SERVER SKILLS TO MICROSOFT SQL SERVER 2014

MSQ3-8 - MOC UPDATING YOUR SQL SERVER SKILLS TO MICROSOFT SQL SERVER 2014 MSQ3-8 - MOC 10977 - UPDATING YOUR SQL SERVER SKILLS TO MICROSOFT SQL SERVER 2014 Categoria: SQL Server 2014 e 2012 INFORMAZIONI SUL CORSO Durata: Categoria: Qualifica Istruttore: Dedicato a: Produttore:

More information

Appunti dei corsi di

Appunti dei corsi di Appunti dei corsi di PROF. G. BONGIOVANNI 2) SVILUPPO DI APPLICAZIONI BASATE SULLO SCAMBIO DI MESSAGGI...2 2.1) Classi di base per la gestione di messaggi... 3 2.1.1) Classe MessageOutput... 3 2.1.2) Classe

More information

package p1; public class Derivation extends Protection { public Derivation() { System.out.println("Derived class constructor");

package p1; public class Derivation extends Protection { public Derivation() { System.out.println(Derived class constructor); PROGRAM:1 WAP to implement the packages //package 1: package p1; public class Protection int n=1; public int n_pub=2; private int n_pri=3; protected int n_pro=4; public Protection () System.out.println("Base

More information

1 (6) Lösningsförslag Objektorienterade applikationer Provdatum Program DAI 2 Läsår 2016/2017, lp 3. Uppgift 1 (1+1+1 p) a)

1 (6) Lösningsförslag Objektorienterade applikationer Provdatum Program DAI 2 Läsår 2016/2017, lp 3. Uppgift 1 (1+1+1 p) a) till dugga P r e l i m i n ä r 1 (6) Kursnamn Objektorienterade applikationer Provdatum 2017-02-09 Program DAI 2 Läsår 2016/2017, lp 3 Examinator Uno Holmer Uppgift 1 (1+1+1 p) a) b) c) public interface

More information

VHDL Packages. I Packages incapsulano elementi che possono essere condivisi tra più entity Un package consiste di due parti:

VHDL Packages. I Packages incapsulano elementi che possono essere condivisi tra più entity Un package consiste di due parti: 1 VHDL Packages I Packages incapsulano elementi che possono essere condivisi tra più entity Un package consiste di due parti: Declaration Dichiarazione di tutti gli elementi contenuti nel package Body

More information

Applet which displays a simulated trackball in the upper half of its window.

Applet which displays a simulated trackball in the upper half of its window. Example: Applet which displays a simulated trackball in the upper half of its window. By dragging the trackball using the mouse, you change its state, given by its x-y position relative to the window boundaries,

More information

Java Programming Language Mr.Rungrote Phonkam

Java Programming Language Mr.Rungrote Phonkam 11 Java Programming Language Mr.Rungrote Phonkam rungrote@it.kmitl.ac.th Contents 1. Core APIs 2. Extension APIs 3. Keyboard Input 4. File Writing 5. Locald 6. Zip Files 7. Ping 8. Sending E-mail 9. Web

More information

System resources. Security Manager.

System resources. Security Manager. Security Manager. Accessing system resources Sometimes, a program requires access to system resources such as system properties, standard input and output, or the current time. Your program could make

More information

Java networking using sockets

Java networking using sockets Teaching Assistant Andrei Vasilateanu Java networking using sockets Introduction One of the software architectures used in distributed computing is client-server. The server offers a service which is requested

More information

Previous lecture: threads G51PRG: Introduction to Programming Second semester Lecture 12 URL

Previous lecture: threads G51PRG: Introduction to Programming Second semester Lecture 12 URL Previous lecture: threads G51PRG: Introduction to Programming Second semester Lecture 12 What is a thread Why use multiple threads Issues and problems involved Java threads Natasha Alechina School of Computer

More information

Errore 500 su installazione Phoca Gallery e Phoca Guestbook su Joomla 2.5. Scritto da ventus85 Domenica 12 Agosto :28

Errore 500 su installazione Phoca Gallery e Phoca Guestbook su Joomla 2.5. Scritto da ventus85 Domenica 12 Agosto :28 In questi giorni ho provato a installare le estensioni Phoca Gallery e Phoca Guestbook, più precisamente le ultime rilasciate ad oggi per Joomla 2.5, la 3.2.1 per la prima e la 2.0.5 per la seconda. In

More information

MW MOC SUPPORTING AND TROUBLESHOOTING WINDOWS 10

MW MOC SUPPORTING AND TROUBLESHOOTING WINDOWS 10 MW10-3 - MOC 10982 - SUPPORTING AND TROUBLESHOOTING WINDOWS 10 Categoria: Windows 10 INFORMAZIONI SUL CORSO Durata: Categoria: Qualifica Istruttore: Dedicato a: Produttore: 5 Giorni Windows 10 Microsoft

More information

Distributed Objects. Remote Method Invokation

Distributed Objects. Remote Method Invokation Distributed Objects Remote Method Invokation Distributed Systems Object Oriented Paradigm invoke method Object 1 Object 2 respond Distributed Object Oriented Paradigm Client Host/Process invoke method

More information

protocols September 15,

protocols  September 15, Contents SCI 351 4 Protocols, WWW Internet applications WWW, document technology Lennart Herlaar Original slides by Piet van Oostrum September 15, 2003 SCI351-4 1 X SCI351-4 1 X Internet applications How

More information

COMP 213. Advanced Object-oriented Programming. Lecture 20. Network Programming

COMP 213. Advanced Object-oriented Programming. Lecture 20. Network Programming COMP 213 Advanced Object-oriented Programming Lecture 20 Network Programming Network Programming A network consists of several computers connected so that data can be sent from one to another. Network

More information

Asynchronous Communication using Messaging

Asynchronous Communication using Messaging FACULTY OF AUTOMATION AND COMPUTER SCIENCE COMPUTER SCIENCE DEPARTMENT DISTRIBUTED SYSTEMS Assignment 3 Communication using Messaging A 3.1: The Basics Ioan Salomie Tudor Cioara Ionut Anghel Marcel Antal

More information

Network Programming. Powered by Pentalog. by Vlad Costel Ungureanu for Learn Stuff

Network Programming. Powered by Pentalog. by Vlad Costel Ungureanu for Learn Stuff Network Programming by Vlad Costel Ungureanu for Learn Stuff Java Network Protocols 2 Java Network Protocols 3 Addresses Innet4Address (32-bit) 85.122.23.145 - numeric pentalog.com symbolic Innet6Address

More information

Chapter 2. Network Chat

Chapter 2. Network Chat Chapter 2. Network Chat In a multi-player game, different players interact with each other. One way of implementing this is to have a centralized server that interacts with each client using a separate

More information

John Cowell. Essential Java Fast. How to write object oriented software for the Internet. with 64 figures. Jp Springer

John Cowell. Essential Java Fast. How to write object oriented software for the Internet. with 64 figures. Jp Springer John Cowell Essential Java Fast How to write object oriented software for the Internet with 64 figures Jp Springer Contents 1 WHY USE JAVA? 1 Introduction 1 What is Java? 2 Is this book for you? 2 What

More information

Homework 3 Huffman Coding. Due Thursday October 11

Homework 3 Huffman Coding. Due Thursday October 11 Homework 3 Huffman Coding Due Thursday October 11 Huffman Coding Implement Huffman Encoding and Decoding and the classes shown on the following slides. You will also need to use Java s stack class HuffmanEncode

More information

CS 180 Final Exam Review 12/(11, 12)/08

CS 180 Final Exam Review 12/(11, 12)/08 CS 180 Final Exam Review 12/(11, 12)/08 Announcements Final Exam Thursday, 18 th December, 10:20 am 12:20 pm in PHYS 112 Format 30 multiple choice questions 5 programming questions More stress on topics

More information

CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2012

CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2012 CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2012 Name: This exam consists of 5 problems on the following 8 pages. You may use your double- sided hand- written 8 ½ x 11 note sheet

More information

Software Practice 1 - Socket

Software Practice 1 - Socket Software Practice 1 - Socket Terms of socket programming Socket Implementation (TCP, UDP) Socket with multithread Serialization Lab practice Prof. Joonwon Lee T.A. Jaehyun Song Jongseok Kim T.A. Sujin

More information

Java 網路程式設計. Copyright 2009 Chia-Hui Huang. Copyright 2009 Chia-Hui Huang

Java 網路程式設計. Copyright 2009 Chia-Hui Huang. Copyright 2009 Chia-Hui Huang - 利用 ServerSocket public void close() Given the name of a host, returns an array of its IP addresses Return an IP address for the given host name. Returns the IP address string in textual presentation.

More information

JAVA EXAMPLES - SOLVING DEADLOCK

JAVA EXAMPLES - SOLVING DEADLOCK JAVA EXAMPLES - SOLVING DEADLOCK http://www.tutorialspoint.com/javaexamples/thread_deadlock.htm Copyright tutorialspoint.com Problem Description: How to solve deadlock using thread? Solution: Following

More information

CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2012

CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2012 CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2012 Name: This exam consists of 5 problems on the following 8 pages. You may use your double- sided hand- written 8 ½ x 11 note sheet

More information

Java for Interfaces and Networks (DT3029)

Java for Interfaces and Networks (DT3029) Java for Interfaces and Networks (DT3029) Lecture 3 Threads and Networking Federico Pecora federico.pecora@oru.se Center for Applied Autonomous Sensor Systems (AASS) Örebro University, Sweden Capiscum

More information

Midterm assessment - MAKEUP Fall 2010

Midterm assessment - MAKEUP Fall 2010 M257 MTA Faculty of Computer Studies Information Technology and Computing Date: /1/2011 Duration: 60 minutes 1-Version 1 M 257: Putting Java to Work Midterm assessment - MAKEUP Fall 2010 Student Name:

More information

MOC6231 Maintaining a Microsoft SQL Server 2008 Database

MOC6231 Maintaining a Microsoft SQL Server 2008 Database Tel. +39 02 365738 info@overneteducation.it www.overneteducation.it MOC6231 Maintaining a Microsoft SQL Server 2008 Database Durata: 4.5 gg Descrizione Questo corso intende fornire agli allievi le conoscenze

More information

Java Threads. Multitasking vs Multithreading. Avere la possibilita di eseguire contemporamente diverse attivita (job)

Java Threads. Multitasking vs Multithreading. Avere la possibilita di eseguire contemporamente diverse attivita (job) Java s 1 Multitasking vs Multithreading Multitasking: Avere la possibilita di eseguire contemporamente diverse attivita (job) Multithreading: Un thread e un singolo flusso di esecuzione Insieme multiplo

More information

CONTENTS. Chapter 1 Getting Started with Java SE 6 1. Chapter 2 Exploring Variables, Data Types, Operators and Arrays 13

CONTENTS. Chapter 1 Getting Started with Java SE 6 1. Chapter 2 Exploring Variables, Data Types, Operators and Arrays 13 CONTENTS Chapter 1 Getting Started with Java SE 6 1 Introduction of Java SE 6... 3 Desktop Improvements... 3 Core Improvements... 4 Getting and Installing Java... 5 A Simple Java Program... 10 Compiling

More information

Lösningsförslag till tentamen

Lösningsförslag till tentamen till tentamen 1 (6) Kursnamn Objektorienterade applikationer Tentamensdatum 2017-08-21 Program DAI2 Läsår 2016/2017, lp 3 Examinator Uno Holmer Uppgift 1 a) (3 p) public class A { private B theb; public

More information

Assignment, part1: feedback and common mistakes. INFO-0010 Samuel HIARD

Assignment, part1: feedback and common mistakes. INFO-0010 Samuel HIARD Assignment, part1: feedback and common mistakes INFO-0010 Samuel HIARD Grades? Not yet Work done at ~70-80% ETA : First week after Spring holidays (should be) Content of the presentation The code of all

More information

2018/2/5 话费券企业客户接入文档 语雀

2018/2/5 话费券企业客户接入文档 语雀 1 2 2 1 2 1 1 138999999999 2 1 2 https:lark.alipay.com/kaidi.hwf/hsz6gg/ppesyh#2.4-%e4%bc%81%e4%b8%9a%e5%ae%a2%e6%88%b7%e6%8e%a5%e6%94%b6%e5%85%85%e5 1/8 2 1 3 static IAcsClient client = null; public static

More information

Chapter 4: Processes

Chapter 4: Processes Chapter 4: Processes Process Concept Process Scheduling Operations on Processes Cooperating Processes Interprocess Communication Communication in Client-Server Systems 4.1 Process Concept An operating

More information

CS 3331 Advanced Object-Oriented Programming Final Exam

CS 3331 Advanced Object-Oriented Programming Final Exam Fall 2015 (Thursday, December 3) Name: CS 3331 Advanced Object-Oriented Programming Final Exam This test has 5 questions and pages numbered 1 through 10. Reminders This test is closed-notes and closed-book.

More information

Transport layer protocols. Lecture 15: Operating Systems and Networks Behzad Bordbar

Transport layer protocols. Lecture 15: Operating Systems and Networks Behzad Bordbar Transport layer protocols Lecture 15: Operating Systems and Networks Behzad Bordbar 78 Interprocess communication Synchronous and asynchronous comm. Message destination Reliability Ordering Client Server

More information

Esempio con Google Play tore Example with Google Play tore

Esempio con Google Play tore Example with Google Play tore Guida all installazione ed uso dell App VR Tour Camerata Picena Per installare l App occorre aprire lo Store del vostro smartphone (Play Store o App Store) e cercare l App con parola chiave Camerata Picena.

More information

Chapter 4: Processes. Process Concept. Process State

Chapter 4: Processes. Process Concept. Process State Chapter 4: Processes Process Concept Process Scheduling Operations on Processes Cooperating Processes Interprocess Communication Communication in Client-Server Systems 4.1 Process Concept An operating

More information

Today. Robotics and Autonomous Systems. Jason and LeJOS. Jason and LeJOS. Lecture 23: LeJOS and Jason. Richard Williams

Today. Robotics and Autonomous Systems. Jason and LeJOS. Jason and LeJOS. Lecture 23: LeJOS and Jason. Richard Williams Today Robotics and Autonomous Systems Lecture 23: LeJOS and Jason Richard Williams Department of Computer Science University of Liverpool Today we will just go through an example of how to interface Jason

More information

Robotics and Autonomous Systems

Robotics and Autonomous Systems 1 / 59 Robotics and Autonomous Systems Lecture 23: LeJOS and Jason Simon Parsons Department of Computer Science University of Liverpool 2 / 59 Today Today we will just go through an example of how to interface

More information

Robotics and Autonomous Systems

Robotics and Autonomous Systems Robotics and Autonomous Systems Lecture 23: LeJOS and Jason Simon Parsons Department of Computer Science University of Liverpool 1 / 59 Today Today we will just go through an example of how to interface

More information

class Class1 { /// <summary> /// The main entry point for the application. /// </summary>

class Class1 { /// <summary> /// The main entry point for the application. /// </summary> Project 06 - UDP Client/Server Applications In this laboratory project you will build a number of Client/Server applications using C# and the.net framework. The first will be a simple console application

More information

Concurrency in JavaFX. Tecniche di Programmazione A.A. 2014/2015

Concurrency in JavaFX. Tecniche di Programmazione A.A. 2014/2015 Concurrency in JavaFX Tecniche di Programmazione Summary 1. The problem 2. javafx.concurrent package 2 The problem Concurrency in JavaFX UI Responsiveness JavaFX is single threaded The JavaFX application

More information

MWS3-3 - MOC NETWORKING WITH WINDOWS SERVER 2016

MWS3-3 - MOC NETWORKING WITH WINDOWS SERVER 2016 MWS3-3 - MOC 20741 - NETWORKING WITH WINDOWS SERVER 2016 Categoria: Windows Server 2016 INFORMAZIONI SUL CORSO Durata: Categoria: Qualifica Istruttore: Dedicato a: Produttore: 5,00000 Giorni Windows Server

More information

CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2013

CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2013 CSCI 136 Written Exam #1 Fundamentals of Computer Science II Spring 2013 Name: This exam consists of 5 problems on the following 6 pages. You may use your double-sided hand-written 8 ½ x 11 note sheet

More information

CSCI Computer Networking: Application Layer Programming George Blankenship. Programming George Blankenship 1

CSCI Computer Networking: Application Layer Programming George Blankenship. Programming George Blankenship 1 CSCI 6431 Computer Networking: Application Layer Programming George Blankenship Programming George Blankenship 1 Lecture Outline Programming concepts PDUs and SDUs Transport Interface System-to-system

More information

Topic 10: Network Programming

Topic 10: Network Programming Topic 10: Network Programming Client-Server Model Host and Port Socket Implementing Client Implementing Server Implementing Server for Multiple Clients Client-Server Model Clients Request a server to provide

More information