C/S架构学习之基于UDP的本地通信(客户机)

  • 基于UDP的本地通信(客户机):
  • 创建流程:
  • 一、创建数据报式套接字(socket函数):
c 复制代码
		int sock_fd = socket(AF_UNIX,SOCK_DGRAM,0);
	    if(-1 == sock_fd)
	    {
	        perror("socket error");
	        exit(-1);
	    }
  • 二、创建客户机和服务器的本地网络信息结构体并填充客户机和服务器本地网络信息结构体 (struct sockaddr_un):
  • 本地网络信息结构体:
c 复制代码
	#include <sys/un.h>
	struct sockaddr_un {
	    sa_family_t sun_family;               //AF_UNIX
	    char        sun_path[108];            //pathname
	};
c 复制代码
		struct sockaddr_un serveraddr,clientaddr;
	    socklen_t serveraddr_len = sizeof(serveraddr);
	    socklen_t clientaddr_len = sizeof(clientaddr);
	
	    memset(&serveraddr,0,serveraddr_len);
	    memset(&clientaddr,0,clientaddr_len);
	
	    serveraddr.sun_family = AF_UNIX;
	    clientaddr.sun_family = AF_UNIX;
	
	    strcpy(serveraddr.sun_path,"./udpserver");
	    strcpy(clientaddr.sun_path,"./udpclient");
  • 三、客户机绑定数据报式套接字(bind函数):
c 复制代码
		if(-1 == bind(sock_fd,(struct sockaddr *)&clientaddr,clientaddr_len))
	    {
	        perror("bind error");
	        exit(-1);
	    }
  • 四、客户机端发收数据(sendto函数、recvfrom函数):
c 复制代码
			memset(buf,0,sizeof(buf));
	
	        fgets(buf,sizeof(buf),stdin);
	        buf[strlen(buf) - 1] = '\0';
	        int ret1 = sendto(sock_fd,buf,sizeof(buf),0,(struct sockaddr *)&serveraddr,serveraddr_len);
	        if(-1 == ret1)
	        {
	            perror("sendto error");
	            exit(-1);
	        }
	
	        int ret2 = recvfrom(sock_fd,buf,sizeof(buf),0,(struct sockaddr*)&serveraddr,&serveraddr_len);
	        if(-1 == ret2)
	        {
	            perror("recvfrom error");
	            exit(-1);
	        }
	
	        printf("服务器[%s]发来应答消息[%s]\n",serveraddr.sun_path,buf);
  • 五、关闭套接字(close函数):
c 复制代码
	close(sock_fd);
  • 示例代码:
c 复制代码
	#include <stdio.h>
	#include <string.h>
	#include <stdlib.h>
	
	#include <sys/socket.h>
	#include <sys/types.h>
	
	#include <unistd.h>
	#include <stdbool.h>
	#include <sys/un.h>
	
	#include <arpa/inet.h>
	#include <netinet/ip.h>
	
	int main(int argc, char const *argv[])
	{
	    //创建套接字
	    int sock_fd = socket(AF_UNIX,SOCK_DGRAM,0);
	    if(-1 == sock_fd)
	    {
	        perror("socket error");
	        exit(-1);
	    }
	    //填充网络信息结构体
	
	    struct sockaddr_un serveraddr,clientaddr;
	    socklen_t serveraddr_len = sizeof(serveraddr);
	    socklen_t clientaddr_len = sizeof(clientaddr);
	
	    memset(&serveraddr,0,serveraddr_len);
	    memset(&clientaddr,0,clientaddr_len);
	
	    serveraddr.sun_family = AF_UNIX;
	    clientaddr.sun_family = AF_UNIX;
	
	    strcpy(serveraddr.sun_path,"./udpserver");
	    strcpy(clientaddr.sun_path,"./udpclient");
	
	
	    //绑定套接字
	    if(-1 == bind(sock_fd,(struct sockaddr *)&clientaddr,clientaddr_len))
	    {
	        perror("bind error");
	        exit(-1);
	    }
	
	    printf("基于UDP的本地通信客户机启动!!!\n");
	
	    char buf[128] = {0};
	    //收发数据
	    while(true)
	    {
	        memset(buf,0,sizeof(buf));
	
	        fgets(buf,sizeof(buf),stdin);
	        buf[strlen(buf) - 1] = '\0';
	        int ret1 = sendto(sock_fd,buf,sizeof(buf),0,(struct sockaddr *)&serveraddr,serveraddr_len);
	        if(-1 == ret1)
	        {
	            perror("sendto error");
	            exit(-1);
	        }
	
	        int ret2 = recvfrom(sock_fd,buf,sizeof(buf),0,(struct sockaddr*)&serveraddr,&serveraddr_len);
	        if(-1 == ret2)
	        {
	            perror("recvfrom error");
	            exit(-1);
	        }
	
	        printf("服务器[%s]发来应答消息[%s]\n",serveraddr.sun_path,buf);
	
	
	
	    }
	    //关闭套接字
	    close(sock_fd);
	
	    return 0;
	}
  • 运行结果:
c 复制代码
	基于UDP的本地通信客户机启动!!!
	hello
	服务器[./udpserver]发来应答消息[hello---------k]
	I Love China!!!
	服务器[./udpserver]发来应答消息[I Love China!!!---------k]
	miss U
	服务器[./udpserver]发来应答消息[miss U---------k]
  • 特别注意:
  • strcpy(serveraddr.sun_path,"./udpserver");strcpy(clientaddr.sun_path,"./udpclient");代码段中的udpserver文件udpclient文件套接字文件
  • 如下所示:
c 复制代码
	srwxrwxr-x 1 linux linux     0 11月 11 01:18 udpclient
	srwxrwxr-x 1 linux linux     0 11月 11 01:18 udpserver
相关推荐
Python私教几秒前
GenericAgent记忆系统深度解析:四层架构如何让AI拥有永不遗忘的大脑
网络·人工智能·架构
AI进化营-智能译站2 分钟前
ROS2 C++开发系列16-智能指针管理传感器句柄|告别ROS2节点内存泄漏与野指针
java·c++·算法·ai
Ronny__4 分钟前
Harness 与 Koa2 登录实践(二):小步能跑通——从 `/health` 到会话 Cookie
架构
chao1898447 分钟前
完整MES系统实现 (C# 客户端服务器)
服务器·windows·c#
她说彩礼65万23 分钟前
C语言 文件
linux·服务器·c语言
txg66634 分钟前
自动驾驶领域热点简报(2026-04-26 ~ 2026-05-03)
linux·人工智能·自动驾驶
CS创新实验室36 分钟前
从盘边到芯端——硬盘接口七十年变迁史
算法·磁盘调度
二哈赛车手42 分钟前
新人笔记---ES和kibana启动问题以及一些常用的linux的错误排查方法,以及ES,数据库泄密解决方案[超详细]
java·linux·数据库·spring boot·笔记·elasticsearch
嵌入式×边缘AI:打怪升级日志1 小时前
嵌入式Linux开发核心自测题(全系列精华浓缩)
java·linux·运维
_codemonster1 小时前
系统分析师刷题系列--操作系统(二)
服务器·系统架构