Scritto il client; rimaneggiate le cose per debuggare.
authorSimone Piccardi <piccardi@gnulinux.it>
Tue, 12 Jun 2001 22:17:22 +0000 (22:17 +0000)
committerSimone Piccardi <piccardi@gnulinux.it>
Tue, 12 Jun 2001 22:17:22 +0000 (22:17 +0000)
sources/Makefile
sources/SimpleDaytimeTCPClient.c
sources/SimpleEchoTCPClient.c [new file with mode: 0644]
sources/SimpleEchoTCPServer.c

index 879aa31190b5367b6aab580c101792b9ef259ac0..3ff7b74e73307b80d7d51149d743a05f316659a6 100644 (file)
@@ -3,11 +3,13 @@
 #
 # C flags
 CC=gcc
 #
 # C flags
 CC=gcc
-CFLAGS= -Wall 
+CFLAGS= -Wall -g 
 CFLADJ=-c 
 
 OBJ = SockRead.o SockWrite.o
 
 CFLADJ=-c 
 
 OBJ = SockRead.o SockWrite.o
 
+echo: SimpleEchoTCPClient.c $(OBJ) 
+       $(CC) $(CFLAGS) SimpleEchoTCPClient.c $(OBJ) -o echo
 
 echod: SimpleEchoTCPServer.c $(OBJ) 
        $(CC) $(CFLAGS) SimpleEchoTCPServer.c $(OBJ) -o echod
 
 echod: SimpleEchoTCPServer.c $(OBJ) 
        $(CC) $(CFLAGS) SimpleEchoTCPServer.c $(OBJ) -o echod
@@ -27,6 +29,7 @@ $(OBJ): wrappers.h
 
 .PHONY : clean
 clean:
 
 .PHONY : clean
 clean:
+       rm -f daytime iterdaytimed daytimed echod echo
        rm -f *~
        rm -f *.o
        rm -f daytime
        rm -f *~
        rm -f *.o
        rm -f daytime
index 7704c8a892a663c6370d16a8a9e1a833f1cd24c1..069b4117ffc7a11a76b03ecfb83062fdb84045d8 100644 (file)
@@ -8,7 +8,7 @@
  *
  * Usage: daytime -h give all info's
  *
  *
  * Usage: daytime -h give all info's
  *
- * $Id: SimpleDaytimeTCPClient.c,v 1.1 2001/04/02 23:24:42 piccardi Exp $ 
+ * $Id: SimpleDaytimeTCPClient.c,v 1.2 2001/06/12 22:17:22 piccardi Exp $ 
  *
  ****************************************************************/
 /* 
  *
  ****************************************************************/
 /* 
@@ -69,7 +69,7 @@ int main(int argc, char *argv[])
     /* initialize address */
     memset((void *) &serv_add, 0, sizeof(serv_add)); /* clear server address */
     serv_add.sin_family = AF_INET;                   /* address type is INET */
     /* initialize address */
     memset((void *) &serv_add, 0, sizeof(serv_add)); /* clear server address */
     serv_add.sin_family = AF_INET;                   /* address type is INET */
-    serv_add.sin_port = htons(13);                   /* daytime post is 13 */
+    serv_add.sin_port = htons(13);                   /* daytime port is 13 */
     /* build address using inet_pton */
     if ( (inet_pton(AF_INET, argv[optind], &serv_add.sin_addr)) <= 0) {
        perror("Address creation error");
     /* build address using inet_pton */
     if ( (inet_pton(AF_INET, argv[optind], &serv_add.sin_addr)) <= 0) {
        perror("Address creation error");
diff --git a/sources/SimpleEchoTCPClient.c b/sources/SimpleEchoTCPClient.c
new file mode 100644 (file)
index 0000000..feac786
--- /dev/null
@@ -0,0 +1,116 @@
+/****************************************************************
+ *
+ * Program SimpleEchoTCPClient: 
+ * Simple TCP client for echo service (port 7)
+ *
+ * Author: Simone Piccardi
+ * Jun. 2001
+ *
+ * Usage: echo -h give all info's
+ *
+ * $Id: SimpleEchoTCPClient.c,v 1.1 2001/06/12 22:17:22 piccardi Exp $
+ *
+ ****************************************************************/
+/* 
+ * Include needed headers
+ */
+#include <sys/types.h>   /* predefined types */
+#include <unistd.h>      /* include unix standard library */
+#include <arpa/inet.h>   /* IP addresses conversion utiliites */
+#include <sys/socket.h>  /* socket library */
+#include <stdio.h>      /* include standard I/O library */
+
+#include "wrappers.h"
+
+#define MAXLINE 256
+void usage(void);
+void EchoClient(FILE * filein, int socket);
+
+/* Program begin */
+int main(int argc, char *argv[])
+{
+/* 
+ * Variables definition  
+ */
+    int sock_fd, i;
+    struct sockaddr_in serv_add;
+    /*
+     * Input section: decode parameters passed in the calling 
+     * Use getopt function
+     */
+    opterr = 0;         /* don't want writing to stderr */
+    while ( (i = getopt(argc, argv, "h")) != -1) {
+       switch (i) {
+       /* 
+        * Handling options 
+        */ 
+       case 'h':  
+           printf("Wrong -h option use\n");
+           usage();
+           return(0);
+           break;
+       case '?':   /* unrecognized options */
+           printf("Unrecognized options -%c\n",optopt);
+           usage();
+       default:    /* should not reached */
+           usage();
+       }
+    }
+    /* ***********************************************************
+     * 
+     *          Options processing completed
+     *
+     *               Main code beginning
+     * 
+     * ***********************************************************/
+    /* create socket */
+    if ( (sock_fd = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
+       perror("Socket creation error");
+       return -1;
+    }
+    /* initialize address */
+    memset((void *) &serv_add, 0, sizeof(serv_add)); /* clear server address */
+    serv_add.sin_family = AF_INET;                   /* address type is INET */
+    serv_add.sin_port = htons(7);                    /* echo port is 7 */
+    /* build address using inet_pton */
+    if ( (inet_pton(AF_INET, argv[optind], &serv_add.sin_addr)) <= 0) {
+       perror("Address creation error");
+       return -1;
+    }
+    /* extablish connection */
+    if (connect(sock_fd, (struct sockaddr *)&serv_add, sizeof(serv_add)) < 0) {
+       perror("Connection error");
+       return -1;
+    }
+    /* read daytime from server */
+    EchoClient(stdin, sock_fd);
+    /* normal exit */
+    return 0;
+}
+/*
+ * routine to print usage info and exit 
+ */
+void usage(void) {
+    printf("Take daytime from a remote host \n");
+    printf("Usage:\n");
+    printf("  daytime [-h] [-v] [host in dotted decimal form] \n");
+    printf("  -v          set verbosity on\n");
+    printf("  -h          print this help\n");
+    exit(1);
+}
+
+void EchoClient(FILE * filein, int socket) 
+{
+    char sendbuff[MAXLINE], recvbuff[MAXLINE];
+    int nread; 
+    while (fgets(sendbuff, MAXLINE, filein) != NULL) {
+       SockWrite(socket, sendbuff, strlen(sendbuff)); 
+       if ( (nread = SockRead(socket, recvbuff, MAXLINE)) == 0) {
+           perror("Sever read error:");
+           exit(-1);
+       }
+       recvbuff[nread] = 0;
+       fputs(recvbuff, stdout);
+    }
+    return;
+}
index 8c0dff80698b6ff5806582a81803625625015d38..9611e365eb2856d3e75f9de0c019c80a8896a1d9 100644 (file)
@@ -8,7 +8,7 @@
  *
  * Usage: echod
  *
  *
  * Usage: echod
  *
- * $Id: SimpleEchoTCPServer.c,v 1.2 2001/06/11 22:15:57 piccardi Exp $ 
+ * $Id: SimpleEchoTCPServer.c,v 1.3 2001/06/12 22:17:22 piccardi Exp $ 
  *
  ****************************************************************/
 /* 
  *
  ****************************************************************/
 /* 
@@ -129,7 +129,8 @@ void SockEcho(int sockfd) {
     int nread, nwrite;
     
     /* main loop, reading 0 char means client close connection */
     int nread, nwrite;
     
     /* main loop, reading 0 char means client close connection */
-    while ( (nread = SockRead(sockfd, buffer, MAXLINE)) != 0) {
+    while ( (nread = read(sockfd, buffer, MAXLINE)) != 0) {
+       printf("Letti %d bytes, %s ", nread, buffer);
        nwrite = SockWrite(sockfd, buffer, nread);
     }
     return;
        nwrite = SockWrite(sockfd, buffer, nread);
     }
     return;