C语言实现TCP服务端

一 前言

上次实现了客户端的TCP通信代码,这次来实现TCP服务端.

二 代码实现

  1. 前期文章
    C语言TCP客户端获取时间
    Unix网络编程卷一第三章笔记

2.代码

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <string.h>

#include <sys/socket.h>
#include <netinet/in.h>

#include <unistd.h>


#define MAX_LINE 1024
#define LISTENQ  10 //最大连接数量/2

void send_error(char *error);

int main () {

	int sockfd ,connfd;//套接字、连接描述符
	struct sockaddr_in servaddr;

	char message[MAX_LINE]="";

	
	if( (sockfd = socket(AF_INET,SOCK_STREAM,0)) <0) {
		send_error("socket error");
	}

	//初始化套接字结构,TCP协议,server IP and port
	bzero(&servaddr,sizeof(servaddr));//清0操作
	servaddr.sin_family = AF_INET;
	servaddr.sin_port = htons(5330);//port

	servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
	if( bind(sockfd,(struct sockaddr *)&servaddr,sizeof(servaddr)) < 0)
		send_error("blind error");

	if(listen(sockfd,LISTENQ) <0)
		send_error("listen error");
		
	while (1) {
		if( (connfd = accept(sockfd,(struct sockaddr *)NULL,NULL) ) <0)
			send_error("46 accept error");
		time_t ticks;
		if( (ticks= time(NULL))<0){
			send_error("time error");
		}
		snprintf(message,sizeof(message),"%24s\r\n",ctime(&ticks));

		if (write(connfd,message,strlen(message))<0) {
			send_error("write error");
		}

		if( close (connfd)<0) {
			send_error("close error");
		}

	}

	return 0;
}



void send_error(char *error){
	perror(error);
	exit(0);

}

3 代码调试
可利用网上的免费网络调试助手(USR-TCP232-Test V1.4.exe)或者用客户端代码进行调试

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TCP是一种可靠的传输协议,因此在实现TCP服务端重连时,需要考虑如下几个方面: 1. 断开连接的检测 服务端需要定期检测与客户端的连接是否已经断开,可以通过定时发送心跳包的方式来实现。如果服务端检测到连接已经断开,可以将之前的套接字关闭,并重新创建一个套接字来监听客户端的连接请求。 2. 重连的处理 当服务端检测到与客户端的连接已经断开后,需要重新创建一个套接字来监听客户端的连接请求。在客户端重新连接后,服务端需要重新与客户端建立连接,并进行数据的交互。 下面是一个简单的C语言实现TCP服务端重连的示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <errno.h> #include <unistd.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #define PORT 8888 #define MAXLINE 1024 int main(int argc, char **argv) { int listenfd, connfd; struct sockaddr_in servaddr, cliaddr; socklen_t clilen; char buf[MAXLINE]; int n; // 创建套接字 if ((listenfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { perror("socket error"); exit(1); } // 设置地址结构体 memset(&servaddr, 0, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_addr.s_addr = htonl(INADDR_ANY); servaddr.sin_port = htons(PORT); // 绑定套接字 if (bind(listenfd, (struct sockaddr *)&servaddr, sizeof(servaddr)) == -1) { perror("bind error"); exit(1); } // 监听套接字 if (listen(listenfd, 10) == -1) { perror("listen error"); exit(1); } while (1) { // 接受客户端连接 clilen = sizeof(cliaddr); if ((connfd = accept(listenfd, (struct sockaddr *)&cliaddr, &clilen)) == -1) { perror("accept error"); continue; } // 连接成功 printf("connection established\n"); while (1) { // 接收数据 n = read(connfd, buf, MAXLINE); if (n == -1) { perror("read error"); break; } else if (n == 0) { printf("client closed\n"); break; } // 打印数据 buf[n] = '\0'; printf("recv: %s", buf); // 发送数据 if (write(connfd, buf, n) == -1) { perror("write error"); break; } } // 关闭套接字 close(connfd); } return 0; } ``` 在上面的示例代码中,我们使用了一个无限循环来接受客户端的连接,并在连接成功后进入另一个无限循环来接收客户端发送的数据。如果客户端断开连接,服务端会关闭套接字,并等待下一个客户端连接。如果服务端检测到连接已经断开,会关闭之前的套接字,并重新创建一个套接字来监听客户端的连接请求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值