Linux TCP迭代回声服务器与客户端模式_怎么理解通过因特网完成有效数据传输(1)

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

#define BUF_SIZE 1024

void Error_Func(char* ErrorMessage);

int main(int argc,char* argv[])
{
int serv_sock;
int clnt_sock;

struct sockaddr_in serv_addr;
struct sockaddr_in clnt_addr;
socklen_t clnt_addr_size;

char message[BUF_SIZE];
int str_len,i;

if(argc != 2)
{
	printf("Usage : %s <port> \n",argv[0]);
	exit(1);
}

serv_sock = socket(PF_INET,SOCK_STREAM,0);
if(serv_sock == -1)
	Error\_Func("socket() error");

memset(&serv_addr,0,sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
serv_addr.sin_addr.s_addr = htonl(INADDR_ANY);
serv_addr.sin_port = htons(atoi(argv[1]));

if(bind(serv_sock,(struct sockaddr\*)&serv_addr,sizeof(serv_addr)) == -1)
	Error\_Func("bind() error");

if(listen(serv_sock,5) == -1)
	Error\_Func("listen() error");

clnt_addr_size = sizeof(clnt_addr);

for(i=0;i<5;i++)
{
	clnt_sock = accept(serv_sock,(struct sockaddr\*)&clnt_addr,&clnt_addr_size);
	//if(clnt\_sock = -1)
		//Error\_Func("accept() error"); 
	//else
		//printf("Connected Client %d \n",i+1);
	while((str_len = read(clnt_sock,message,BUF_SIZE))!=0)
	{
		printf("received the message from client: \n %s",message);
		write(clnt_sock,message,str_len);
	}
		
	close(clnt_sock);
}
close(serv_sock);

return 0;

}

void Error_Func(char* ErrorMessage)
{
fputs(ErrorMessage,stderr);
fputc(‘\n’,stderr);
exit(1);
}


12、echoclient.c



#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>

#define BUF_SIZE 1024

void Error_Func(char* ErrorMessage);
int main(int argc,char* argv[])
{
int sock;
struct sockaddr_in serv_addr;
char message[BUF_SIZE];
int str_len;
if(argc != 3)
{
printf(“Usage : %s ”,argv[0]);
}

sock = socket(PF_INET,SOCK_STREAM,0);
if(sock == -1)
	Error\_Func("socket() error");
memset(&serv_addr,0,sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
serv_addr.sin_addr.s_addr = inet\_addr(argv[1]);
serv_addr.sin_port = htons(atoi(argv[2]));

if(connect(sock,(struct sockaddr\*) &serv_addr,sizeof(serv_addr)) == -1)
	Error\_Func("connect() error");
else
	puts("Connected success.....");

while(1)
{
	fputs("Inputs message(Q to exit):",stdout);
	fgets(message,BUF_SIZE,stdin);
	if(!strcmp(message,"Q\n") || !strcmp(message,"q\n"))
		break;
	write(sock,message,strlen(message));
	str_len = read(sock,message,BUF_SIZE-1);
	message[str_len] = 0;
	printf("Message From Server : %s\n",message);
}
close(sock);

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的客户端服务器端C代码示例,它使用TCP连接在Linux上进行数据传输服务器端代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/socket.h> #include <netinet/in.h> #define PORT 8080 int main(int argc, char const *argv[]) { int server_fd, new_socket, valread; struct sockaddr_in address; int opt = 1; int addrlen = sizeof(address); char buffer[1024] = {0}; char *hello = "Hello from server"; // 创建TCP套接字 if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) { perror("socket failed"); exit(EXIT_FAILURE); } // 设置套接字选项 if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEADDR | SO_REUSEPORT, &opt, sizeof(opt))) { perror("setsockopt failed"); exit(EXIT_FAILURE); } address.sin_family = AF_INET; address.sin_addr.s_addr = INADDR_ANY; address.sin_port = htons(PORT); // 绑定套接字到指定地址和端口号 if (bind(server_fd, (struct sockaddr *)&address, sizeof(address)) < 0) { perror("bind failed"); exit(EXIT_FAILURE); } // 监听套接字 if (listen(server_fd, 3) < 0) { perror("listen failed"); exit(EXIT_FAILURE); } // 等待客户端连接并接受连接 if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen)) < 0) { perror("accept failed"); exit(EXIT_FAILURE); } // 从客户端读取数据 valread = read(new_socket, buffer, 1024); printf("%s\n", buffer); // 向客户端发送数据 send(new_socket, hello, strlen(hello), 0); printf("Hello message sent\n"); return 0; } ``` 客户端代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #define PORT 8080 int main(int argc, char const *argv[]) { int sock = 0, valread; struct sockaddr_in serv_addr; char *hello = "Hello from client"; char buffer[1024] = {0}; // 创建TCP套接字 if ((sock = socket(AF_INET, SOCK_STREAM, 0)) < 0) { perror("socket failed"); exit(EXIT_FAILURE); } serv_addr.sin_family = AF_INET; serv_addr.sin_port = htons(PORT); // 将IP地址从点十进制转换为网络字节序 if (inet_pton(AF_INET, "127.0.0.1", &serv_addr.sin_addr) <= 0) { perror("inet_pton failed"); exit(EXIT_FAILURE); } // 连接服务器 if (connect(sock, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0) { perror("connect failed"); exit(EXIT_FAILURE); } // 向服务器发送数据 send(sock, hello, strlen(hello), 0); printf("Hello message sent\n"); // 从服务器读取数据 valread = read(sock, buffer, 1024); printf("%s\n", buffer); return 0; } ``` 这个例子中,服务器监听端口8080,并等待客户端连接。一旦客户端连接,服务器读取客户端发送的数据并向客户端发送欢迎消息。客户端连接到服务器,并向服务器发送消息,然后读取服务器发送的响应。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值