本次实验利用TCP/IP, 语言环境为 C/C++
利用套接字Socket编程,实现Server/CLient 之间简单的通讯。
结果应为类似所示:
下面贴上代码(参考参考...)
Server 部分:
1 /* TCPServer.cpp - main */ 2 3 #include <stdlib.h> 4 #include <stdio.h> 5 #include <winsock2.h> 6 #include <time.h> 7 #include "conio.h" 8 9 #define QLEN 5 10 #define WSVERS MAKEWORD(2, 0) 11 #define BUFLEN 20000 12 #pragma comment(lib,"ws2_32.lib") //使用winsock 2.2 library 13 /*------------------------------------------------------------------------ 14 * main - Iterative TCP server for TIME service 15 *------------------------------------------------------------------------ 16 */ 17 char buf[20000]; 18 char buf1[20000]; 19 char buf2[20000]; 20 void main(int argc, char *argv[]) 21 /* argc: 命令行参数个数, 例如:C:> TCPServer 8080 22 argc=2 argv[0]="TCPServer",argv[1]="8080" */ 23 { 24 struct sockaddr_in fsin; /* the from address of a client */ 25 SOCKET msock, ssock; /* master & slave sockets */ 26 WSADATA wsadata; 27 char *service = "5050"; 28 struct sockaddr_in sin; /* an Internet endpoint address */ 29 int alen; /* from-address length */ 30 char *pts; /* pointer to time string */ 31 // char pts[2000]; 32 time_t now; /* current time */ 33 int cc; 34 35 WSAStartup(WSVERS, &wsadata); // 加载winsock library。WSVERS指明请求使用的版本。wsadata返回系统实际支持的最高版本 36 msock = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP); // 创建套接字,参数:因特网协议簇(family),流套接字,TCP协议 37 // 返回:要监听套接字的描述符或INVALID_SOCKET 38 39 memset(&sin, 0, sizeof(sin)); // 从&sin开始的长度为sizeof(sin)的内存清0 40 sin.sin_family = AF_INET; // 因特网地址簇(INET-Internet) 41 sin.sin_addr.s_addr = INADDR_ANY; // 监听所有(接口的)IP地址。 42 sin.sin_port = htons((u_short)atoi(service)); // 监听的端口号。atoi--把ascii转化为int,htons--主机序到网络序(16位) 43 bind(msock, (struct sockaddr *)&sin, sizeof(sin)); // 绑定监听的IP地址和端口号 44 45 listen(msock, 5); // 等待建立连接的队列长度为5 46 47 while(!_kbhit()){ // 检测是否有按键 48 alen = sizeof(struct sockaddr); // 取到地址结构的长度 49 ssock = accept(msock, (struct sockaddr *)&fsin, &alen); // 如果有新的连接请求,返回连接套接字,否则,被阻塞。fsin包含客户端IP地址和端口号 50 51 (void) time(&now); // 取得系统时间 52 pts = ctime(&now); // 把时间转换为字符串 53 sprintf(buf,"IP :%s 端口号: %d ",inet_ntoa(fsin.sin_addr),fsin.sin_port); 54 // sprintf(buf,"%d:%d Hello my friends ! %s",inet_ntoa(sin.sin_addr),fsin.sin_port,pts); 55 (void) send(ssock, buf, strlen(pts), 0); // 把缓冲区(指针,长度)的数据发送出去 56 printf(" TCP(Server) Echo增强程序 "); 57 printf(" 时间: %s ", pts); 58 printf(" %s ", buf); // 显示发送字符串 59 printf("请等待接收数据 : "); 60 61 //flag1: 62 // printf(" 您还要传送什么? "); 63 // printf(" 如果想临时改为接收,请键入 * "); 64 // scanf("%s",pts); 65 66 // if(pts[0] == '*') 67 // { 68 // printf(" 请等待接收数据 "); 69 // sprintf(buf1,"%s",pts); 70 // (void) send(ssock, buf1, strlen(pts), 0); 71 // goto flag2; 72 // } 73 // sprintf(buf1,"%s",pts); 74 // (void) send(ssock, buf1, strlen(pts), 0); 75 // goto flag1; 76 // ssock = accept(msock, (struct sockaddr *)&fsin, &alen); 77 78 flag2: cc = recv(ssock, buf1, BUFLEN, 0); 79 if(cc == SOCKET_ERROR || cc==0) 80 printf("Error: %d. ",GetLastError()); //出错。其后必须关闭套接字sock。 81 else if(cc > 0) { 82 buf1[cc] = '