Linux TCP网络编程示例

Linux TCP网络编程示例

[日期:2011-05-01]来源:Linux社区  作者:Comfanter[字体:  ]

  1. #include <sys/types.h>   
  2. #include <sys/socket.h>   
  3. #include <arpa/inet.h>   
  4. #include <netinet/in.h>   
  5. #include <strings.h>   
  6. #include <string.h>   
  7. #include <stdio.h>   
  8. #include <stdlib.h>   
  9. #include <errno.h>   
  10. #include <unistd.h>   
  11. int main(int argc, char *argv[])   
  12. {   
  13.     int sockfd;   
  14.     char buffer[1024];   
  15.     struct sockaddr_in server_addr;   
  16.     int portnumber, nbytes;   
  17.     if (argc != 3) {   
  18.         fprintf(stderr, "Usage:%s hostname portnumber\n\a", argv[0]);   
  19.         exit(1);   
  20.     }   
  21.     if (inet_aton(argv[1], &server_addr.sin_addr) == 0) {   
  22.         fprintf(stderr, "the hostip is not right!");   
  23.         exit(1);   
  24.     }   
  25.     if ((portnumber = atoi(argv[2])) < 0) {   
  26.         fprintf(stderr, "Usage:%s hostname portnumber\n\a", argv[0]);   
  27.         exit(1);   
  28.     }   
  29.     // 创建套接字   
  30.     if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {   
  31.         fprintf(stderr, "Socket Error:%s\n\a", strerror(errno));   
  32.         exit(1);   
  33.     }   
  34.     // 填充服务器的地址信息   
  35.     server_addr.sin_family = AF_INET;   
  36.     server_addr.sin_port = htons(portnumber);   
  37.     // 向服务器发起连接   
  38.     if (connect(sockfd, (struct sockaddr *)&server_addr, sizeof(struct sockaddr)) == -1) {   
  39.         fprintf(stderr, "Connect Error:%s\n\a", strerror(errno));   
  40.         exit(1);   
  41.     }   
  42.     // 连接成功后,从服务器接收信息   
  43.     if ((nbytes = read(sockfd, buffer, 1024)) == -1) {   
  44.         fprintf(stderr, "Read Error:%s\n", strerror(errno));   
  45.         exit(1);   
  46.     }   
  47.     buffer[nbytes] = '\0';   
  48.     printf("I have received:%s\n", buffer);   
  49.     close(sockfd);   
  50.     exit(0);   
  51. }  

 
  1. #include <sys/types.h>   
  2. #include <sys/socket.h>   
  3. #include <arpa/inet.h>   
  4. #include <netinet/in.h>   
  5. #include <strings.h>   
  6. #include <string.h>   
  7. #include <stdio.h>   
  8. #include <stdlib.h>   
  9. #include <errno.h>   
  10. #include <unistd.h>   
  11. int main(int argc, char *argv[])   
  12. {   
  13.     int sockfd, new_fd;   
  14.     struct sockaddr_in server_addr;   
  15.     struct sockaddr_in client_addr;   
  16.     int sin_size, portnumber;   
  17.     char hello[] = "Hello! Are you fine?\n";   
  18.     if (argc != 2) {   
  19.         fprintf(stderr, "Usage:%s portnumber\a\n", argv[0]);   
  20.         exit(1);   
  21.     }   
  22.     if ((portnumber = atoi(argv[1])) < 0) {   
  23.         fprintf(stderr, "Usage:%s portnumber\a\n", argv[0]);   
  24.         exit(1);   
  25.     }   
  26.     // 创建套接字   
  27.     if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {   
  28.         fprintf(stderr, "Socket error:%s\n\a", strerror(errno));   
  29.         exit(1);   
  30.     }   
  31.     // 填充服务器的地址结构   
  32.     bzero(&server_addr, sizeof(struct sockaddr_in));   
  33.     server_addr.sin_family = AF_INET;   
  34.     server_addr.sin_addr.s_addr = htonl(INADDR_ANY);   
  35.     server_addr.sin_port = htons(portnumber);   
  36.     // 套接字绑定地址   
  37.     if (bind(sockfd, (struct sockaddr *)&server_addr, sizeof(struct sockaddr)) == -1) {   
  38.         fprintf(stderr, "Bind error:%s\n\a", strerror(errno));   
  39.         exit(1);   
  40.     }   
  41.     // 进入监听状态   
  42.     if (listen(sockfd, 5) == -1) {   
  43.         fprintf(stderr, "Listen error:%s\n\a", strerror(errno));   
  44.         exit(1);   
  45.     }   
  46.     while (1) {   
  47.         // 接收客户端的连接   
  48.         sin_size = sizeof(struct sockaddr_in);   
  49.         if ((new_fd = accept(sockfd, (struct sockaddr *)&client_addr, (socklen_t *)&sin_size)) == -1) {   
  50.             fprintf(stderr, "Accept error:%s\n\a", strerror(errno));   
  51.             exit(1);   
  52.         }   
  53.         fprintf(stderr, "Server get connection from %s\n", inet_ntoa(client_addr.sin_addr));   
  54.         if (write(new_fd, hello, strlen(hello)) == -1) {   
  55.             fprintf(stderr, "Write error:%s\n", strerror(errno));   
  56.             exit(1);   
  57.         }   
  58.         close(new_fd);   
  59.     }   
  60.     close(sockfd);   
  61.     //  exit(0);   
  62.     return 0;   
  63. }  

Linux TCP网络编程示例

里面包含聊天室的客户端和服务器端的源文件和一份完整的设计报告。 一、 系统概要 本系统能实现基于VC++的网络聊天室系统。有单独的客户端、服务器端。 服务器应用程序能够接受来自客户端的广播,然后向客户端发送本机的IP与服务端口,让客户端接入到服务器进行聊天,检测用户名是否合法(重复),服务器责接收来自客户端的聊天信息,并根据用户的需求发送给指定的人或所有人,能够给出上线下线提示。客户端能够发出连接请求,能编辑发送信息,可以指定发给单人或所有人,能显示聊天人数,上线下线用户等。 二、 通信规范的制定 服务请求规范: 服务器端: (1) 创建一个UDP的套接字,接受来自客户端的广播请求,当请求报文内容为“REQUEST FOR IP ADDRESS AND SERVERPORT”时,接受请求,给客户端发送本服务器TCP聊天室的端口号。 (2) 创建一个主要的TCP协议的套接字负责客户端TCP连接 ,处理它的连接请求事件。 (3)在主要的TCP连接协议的套接字里面再创建TCP套接字保存到动态数组里,在主要的套接字接受请求后 ,就用这些套接字和客户端发送和接受数据。 客户端: (1) 当用户按“连接”按钮时,创建UDP协议套接字,给本地计算机发广播,广播内容为“REQUEST FOR IP ADDRESS AND SERVERPORT”。 (2)当收到服务器端的回应,收到服务器发来的端口号后,关闭UDP连接。根据服务器的IP地址和端口号重新创建TCP连接。 故我思考:客户端一定要知道服务器的一个端口,我假设它知道服务器UDP服务的端口,通过发广播给服务器的UDP服务套接字,然后等待该套接字发回服务器TCP聊天室服务的端口号,IP地址用ReceiveForom也苛刻得到。 通信规范 通信规范的制定主要跟老师给出的差不多,并做了一小点增加: (增加验证用户名是否与聊天室已有用户重复,在服务器给客户端的消息中,增加标志0) ① TCP/IP数据通信 --- “聊天”消息传输格式 客户机 - 服务器 (1)传输“用户名” STX+1+用户名+ETX (2) 悄悄话 STX+2+用户名+”,”+内容+ETX (3) 对所有人说 STX+3+内容+ETX 服务器- 客户机 (0)请求用户名与在线用户名重复 //改进 STX+0+用户名+EXT (1)首次传输在线用户名 STX+1+用户名+ETX (2)传输新到用户名 STX+2+用户名+ETX (3)传输离线用户名 STX+3+用户名+ETX (4)传输聊天数据 STX+4+内容+ETX (注:STX为CHR(2),ETX 为CHR(3)) 三、 主要模块的设计分析 四、 系统运行效果 (要求有屏幕截图) 五、 心得与体会
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值