Linux网络编程实现客户端服务端收发数据功能

客户端代码

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

int main(void)
{
	int st = socket(AF_INET, SOCK_STREAM, 0);//初始化socket

	struct sockaddr_in addr; // 定义一个IP地址的结构
	memset(&addr, 0, sizeof(addr));
	addr.sin_family = AF_INET;// 设置结构地址类型为TCP/IP地址
	addr.sin_port = htons(8080); // 制定一个端口号:8080,htons:将short类型从host字节类型转到net字节类型
	// 将字符类型的IP地址转化为int,赋给addr结构
	//addr.sin_addr.s_addr = inet_addr("127.0.0.1");
	addr.sin_addr.s_addr = inet_addr("192.168.10.210");

	//
	if (connect(st, (struct sockaddr *)&addr, sizeof(addr)) == -1)
	{
		printf("connect failed %s\n", strerror(errno));
		return EXIT_FAILURE;
	}

	char s[1024];
	memset(s, 0, sizeof(1024));
	strcpy(s, "hello world");

	if (send(st, s, strlen(s), 0) == -1)
	{
		printf("send failed %s\n", strerror(errno));
	}
	//sleep(100);
	close(st);

	return EXIT_SUCCESS;
}


服务端代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>

int main(int arg, char *args[])
{
	int st = socket(AF_INET, SOCK_STREAM, 0); //初始化socket

	int on = 1;
	if (setsockopt(st, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) == -1)
	{
		printf("setsockopt failed %s\n", strerror(errno));
		return EXIT_FAILURE;
	}

	struct sockaddr_in addr; // 定义一个IP地址结构
	memset(&addr, 0, sizeof(addr));
	addr.sin_family = AF_INET; // 将addr结构的属性定位为TCP/IP地址
	addr.sin_port = htons(8080); // 将本地字节顺序转化为网络字节顺序
	addr.sin_addr.s_addr = htonl(INADDR_ANY); // INADDR_ANY代表这个server上所有的地址

	// 将ip与server程序绑定
	if (bind(st, (struct sockaddr *) &addr, sizeof(addr)) == -1)
	{
		printf("bind failed %s\n", strerror(errno));
		return EXIT_FAILURE;
	}

	// server端开始listen
	if (listen(st, 20) == -1)
	{
		printf("listen failed %s\n", strerror(errno));
		return EXIT_FAILURE;
	}
	//printf("listen success\n");
	char s[1024];
	int client_st = 0;
	struct sockaddr_in client_addr; // 表示client端的IP地址
	int i;
	for (i = 0; i < 5; i++)
	{
		memset(&client_addr, 0, sizeof(client_addr));
		socklen_t len = sizeof(client_addr);
		// accept会阻塞,直到有客户端连接过来,accept返回client的socket描述符
		client_st = accept(st, (struct sockaddr*) &client_addr, &len);
		if (client_st == -1)
		{
			printf("accept failed %s\n", strerror(errno));
			return EXIT_FAILURE;
		}

		/* 第一个版本
		memset(s, 0, sizeof(1024));
		if (recv(client_st, s, sizeof(s), 0) == -1)
		{
			printf("recv failed %s\n", strerror(errno));
			close(client_st);
			return EXIT_FAILURE;
		}
		printf("revc is %s\n", s);
		close(client_st);*/

		// 第二个版

		/*while (1)
		{
			memset(s, 0, sizeof(1024));
			if (recv(client_st, s, sizeof(s), 0) > 0)
			{
				printf("revc is %s\n", s);
			} else
			{
				printf("recv failed %s\n", strerror(errno));
				break;
			}
		}
		close(client_st);*/

		// 第三个版本
		while (1)
		{
			memset(s, 0, sizeof(1024));
			int rc = recv(client_st, s, sizeof(s), 0);// 是阻塞调用
			if (rc > 0)
			{
				printf("revc is %s\n", s);
			} else
			{
				if (rc == 0)
				{
					printf("client socket closed\n");
				}
				else
				{
					printf("recv failed %s\n", strerror(errno));
				}
				break;
			}
		}
		close(client_st);


	}
	close(st);
	return 0;
}

makefile文件内容

.SUFFIXES:.c .o

CC=gcc
SRCS1=sock.c
SRCS2=server.c

OBJS1=$(SRCS1:.c=.o)
OBJS2=$(SRCS2:.c=.o)
EXEC1=client
EXEC2=server

all: $(OBJS1) $(OBJS2)
	 $(CC) -o $(EXEC1) $(OBJS1)
	 $(CC) -o $(EXEC2) $(OBJS2)
	 @echo '----------------ok------------'

.c.o:
	$(CC) -Wall -g -o $@ -c $<

clean:
	rm -f $(OBJS1)
	rm -f core*



  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
UDP服务端收发主要需要使用Linux下的socket编程。 以下是一个简单的示例代码,实现了UDP服务端收发: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/socket.h> #include <arpa/inet.h> #define BUF_SIZE 1024 void error_handling(char *message); int main(int argc, char *argv[]) { int serv_sock; char message[BUF_SIZE]; int str_len, addr_size; struct sockaddr_in serv_addr, clnt_addr; if (argc != 2) { printf("Usage : %s <port>\n", argv[0]); exit(1); } serv_sock = socket(PF_INET, SOCK_DGRAM, 0); if (serv_sock == -1) { error_handling("UDP socket creation 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_handling("bind() error"); } while (1) { addr_size = sizeof(clnt_addr); str_len = recvfrom(serv_sock, message, BUF_SIZE, 0, (struct sockaddr *) &clnt_addr, &addr_size); if (str_len < 0) { error_handling("recvfrom() error"); } printf("Received message from %s:%d\n", inet_ntoa(clnt_addr.sin_addr), ntohs(clnt_addr.sin_port)); printf("Message: %s\n", message); if (sendto(serv_sock, message, str_len, 0, (struct sockaddr *) &clnt_addr, sizeof(clnt_addr)) == -1) { error_handling("sendto() error"); } } close(serv_sock); return 0; } void error_handling(char *message) { fputs(message, stderr); fputc('\n', stderr); exit(1); } ``` 运行时需要输入监听的端口号作为参数,例如: ``` $ ./udp_server 1234 ``` 运行后,服务端会不断接收客户端发送的消息,并将其原封不动地发送回去。可以使用 `netcat` 命令模拟客户端服务端发送消息: ``` $ echo "Hello, UDP server" | nc -4u localhost 1234 ``` 服务端会输出如下信息: ``` Received message from 127.0.0.1:xxxxx Message: Hello, UDP server ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值