基于C/S模式的简单聊天程序

时间: 2023-10-03 16:04:53 浏览: 42
该简单聊天程序采用了C/S模式,即客户端/服务器模式。客户端通过与服务器建立连接,实现与其他客户端的聊天交流。 服务器端程序: 1. 建立服务器端socket,监听客户端连接请求。 2. 接收客户端连接请求,并建立连接。 3. 接收客户端发来的消息,广播给所有已连接的客户端。 4. 关闭连接。 客户端程序: 1. 建立客户端socket,连接服务器。 2. 发送消息给服务器。 3. 接收服务器广播的消息,显示在客户端界面上。 4. 关闭连接。 下面是服务器端程序的实现: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #define PORT 1234 #define BACKLOG 5 #define MAXDATASIZE 100 int main() { int sockfd, client_fd; struct sockaddr_in my_addr; struct sockaddr_in remote_addr; int sin_size; char buf[MAXDATASIZE]; int recvbytes; if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { perror("socket"); exit(1); } printf("socket success!,sockfd=%d\n",sockfd); my_addr.sin_family = AF_INET; my_addr.sin_port = htons(PORT); my_addr.sin_addr.s_addr = INADDR_ANY; bzero(&(my_addr.sin_zero), 8); if (bind(sockfd, (struct sockaddr *)&my_addr, sizeof(struct sockaddr))== -1) { perror("bind"); exit(1); } printf("bind success!\n"); if (listen(sockfd, BACKLOG) == -1) { perror("listen"); exit(1); } printf("listening....\n"); while(1) { sin_size = sizeof(struct sockaddr_in); if ((client_fd = accept(sockfd, (struct sockaddr *)&remote_addr, &sin_size)) == -1) { perror("accept"); continue; } printf("received a connection from %s:%d\n", inet_ntoa(remote_addr.sin_addr), ntohs(remote_addr.sin_port)); if (!fork()) { if (send(client_fd, "Welcome to my server\n", 22, 0) == -1) perror("send"); while (recvbytes=recv(client_fd, buf, MAXDATASIZE, 0)) { buf[recvbytes] = '\0'; printf("received a message from %s:%d :%s\n", inet_ntoa(remote_addr.sin_addr), ntohs(remote_addr.sin_port), buf); if (send(client_fd, buf, recvbytes, 0) == -1) perror("send"); } close(client_fd); exit(0); } close(client_fd); } close(sockfd); return 0; } ``` 下面是客户端程序的实现: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #define PORT 1234 #define MAXDATASIZE 100 int main(int argc, char *argv[]) { int sockfd, recvbytes; char buf[MAXDATASIZE]; struct sockaddr_in serv_addr; if (argc < 2) { fprintf(stderr, "Please enter the server's hostname!\n"); exit(1); } if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { perror("socket"); exit(1); } serv_addr.sin_family = AF_INET; serv_addr.sin_port = htons(PORT); serv_addr.sin_addr.s_addr = inet_addr(argv[1]); bzero(&(serv_addr.sin_zero), 8); if (connect(sockfd, (struct sockaddr *)&serv_addr, sizeof(struct sockaddr)) == -1) { perror("connect"); exit(1); } if ((recvbytes=recv(sockfd, buf, MAXDATASIZE, 0)) == -1) { perror("recv"); exit(1); } buf[recvbytes] = '\0'; printf("%s", buf); while(1){ printf("Enter message to send:\n"); fgets(buf, MAXDATASIZE, stdin); if (send(sockfd, buf, strlen(buf), 0) == -1) { perror("send"); exit(1); } if ((recvbytes = recv(sockfd, buf, MAXDATASIZE, 0)) == -1) { perror("recv"); exit(1); } buf[recvbytes] = '\0'; printf("Received: %s",buf); } close(sockfd); return 0; } ``` 运行服务器端程序后,服务器会一直监听客户端请求。运行客户端程序,输入服务器的IP地址,即可与服务器建立连接,开始聊天。

相关推荐

最新推荐

recommend-type

基于Java的Socket编写的C/S聊天程序实现

主要介绍了基于Java的Socket编写的C/S聊天程序实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

基于C/S结构的小型餐饮管理系统设计与实现

为使酒店管理(信息工程)专业的学生掌握设计和实现旅游信息管理系统的方法,对酒店餐饮管理工作的业务流程进行了分析,并在此基础上设计了可供学生在管理信息系统设计课程中使用的餐饮管理系统设计方案。...
recommend-type

基于qt编写的c/s模型的简单聊天程序

本文讲解了用qt在linux中实现基于qt编写的c/s模型的简单聊天程序,包括源代码。
recommend-type

基于C/S模式的小区物业管理系统论文(C#)

本系统采用Microsoft Visual Studio 2005作为设计平台,以C#语言结合Microsoft SQL Server2000进行数据库的创建和管理来实现,系统提供了业主的基本管理、物业管理、费用管理、车位使用管理、相关信息的搜索等五大功能...
recommend-type

Python基于Socket实现的简单聊天程序示例

主要介绍了Python基于Socket实现的简单聊天程序,结合简单实例形式分析了Python聊天程序的客户端与服务器端相关实现技巧,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

SQL怎么实现 数据透视表

SQL可以通过使用聚合函数和GROUP BY子句来实现数据透视表。 例如,假设有一个销售记录表,其中包含产品名称、销售日期、销售数量和销售额等信息。要创建一个按照产品名称、销售日期和销售额进行汇总的数据透视表,可以使用以下SQL语句: ``` SELECT ProductName, SaleDate, SUM(SaleQuantity) AS TotalQuantity, SUM(SaleAmount) AS TotalAmount FROM Sales GROUP BY ProductName, SaleDate; ``` 该语句将Sales表按照ProductName和SaleDat
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。