42、网络编程/多点通信和域套接字通信模型20240304

2024-03-05 07:44

本文主要是介绍42、网络编程/多点通信和域套接字通信模型20240304,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、多点通信之广播的收发端实现

1.广播发送端代码:

#include<myhead.h>int main(int argc, const char *argv[])
{int sfd=socket(AF_INET,SOCK_DGRAM,0);//创建套接字if(sfd==-1){perror("socket,error");return -1;}int broadcast=1;//设置套接字广播属性if(setsockopt(sfd,SOL_SOCKET,SO_BROADCAST,&broadcast,sizeof(broadcast))==-1){perror("setsockopt error");return -1;}struct sockaddr_in sin;//广播地址结构体sin.sin_family=AF_INET;sin.sin_port=htons(8888);sin.sin_addr.s_addr=inet_addr("192.168.32.255");char sbuf[128]="";while(1){printf("请输入>>>");fgets(sbuf,sizeof(sbuf),stdin);sbuf[strlen(sbuf)-1]=0;//向广播地址发送数据sendto(sfd,sbuf,strlen(sbuf),0,(struct sockaddr*)&sin,sizeof(sin));printf("发送成功\n");}close(sfd);return 0;
}

2.广播接收端代码:

int main(int argc, const char *argv[])
{int rfd=socket(AF_INET,SOCK_DGRAM,0);//基于ipv4的udp模型实现广播if(rfd==-1){perror("socket error");return -1;}printf("rfd=%d\n",rfd);struct sockaddr_in rin;rin.sin_family=AF_INET;rin.sin_port=htons(8888);//端口号设置rin.sin_addr.s_addr=inet_addr("192.168.32.255");//ip地址主机号全为1的地址为广播地址if(bind(rfd,(struct sockaddr*)&rin,sizeof(rin))==-1)//绑定到广播地址{perror("bind error");return -1;}char rbuf[128]="";while(1){bzero(rbuf,sizeof(rbuf));recv(rfd,rbuf,sizeof(rbuf),0);//接收广播消息printf("收到消息:%s\n",rbuf);}close(rfd);return 0;
}

运行:

二、多点通信之组播的收发实现

1.组播发送端代码

#include<myhead.h>int main(int argc, const char *argv[])
{//创建套接字int rfd=socket(AF_INET,SOCK_DGRAM,0);//基于ipv4的udp模型if(rfd==-1){perror("socket error");return -1;}//绑定端口和ip地址struct sockaddr_in rin;rin.sin_family=AF_INET;rin.sin_port=htons(9999);//自身端口号rin.sin_addr.s_addr=inet_addr("192.168.32.130");//ip地址if(bind(rfd,(struct sockaddr*)&rin,sizeof(rin))==-1){perror("bind error");return -1;}//发送消息struct sockaddr_in sin;sin.sin_family=AF_INET;sin.sin_port=htons(8888);//设置组播的端口号sin.sin_addr.s_addr=inet_addr("224.1.2.3");//组播的ipchar sbuf[128]="";while(1){printf("请输入>>>");fgets(sbuf,sizeof(sbuf),stdin);sbuf[strlen(sbuf)-1]=0;//向组播内发送信息sendto(rfd,sbuf,strlen(sbuf),0,(struct sockaddr*)&sin,sizeof(sin));printf("发送成功\n");}//关闭close(rfd);return 0;
}

2.组播接收端代码

#include<myhead.h>int main(int argc, const char *argv[])
{int rfd=socket(AF_INET,SOCK_DGRAM,0);//创建套接字if(rfd==-1){perror("socket error");return -1;}printf("rfd=%d\n",rfd);//设置加入多播组struct ip_mreqn imr;imr.imr_multiaddr.s_addr=inet_addr("224.1.2.3");//组播ipimr.imr_address.s_addr=inet_addr("192.168.32.130");//本机ipimr.imr_ifindex=2;//网卡编号//设置加入组播if(setsockopt(rfd,IPPROTO_IP,IP_ADD_MEMBERSHIP,&imr,sizeof(imr))==-1){perror("setsockopt error");return -1;}struct sockaddr_in rin;//组播地址信息rin.sin_family=AF_INET;rin.sin_port=htons(8888);rin.sin_addr.s_addr=inet_addr("224.1.2.3");//绑定到组播地址if(bind(rfd,(struct sockaddr*)&rin,sizeof(rin))==-1){perror("bind error");return -1;}char rbuf[128]="";while(1){bzero(rbuf,sizeof(rbuf));recv(rfd,rbuf,sizeof(rbuf),0);//接收组播消息printf("收到消息:%s\n",rbuf);}close(rfd);return 0;
}

运行结果:

三、 流式域套接字(基于tcp)的服务器、客户端实现。

1.服务器代码:

#include<myhead.h>int main(int argc, const char *argv[])
{int sfd=socket(AF_UNIX,SOCK_STREAM,0);//通过设置参数不同创建域套接字 传输方式tcpif(sfd==-1){perror("socket error");return -1;}if(access("./mysocket",F_OK)==0)//判断文件是否存在,如果存在则删除{if(unlink("./mysocket")==-1){perror("unlink error");return -1;}}struct sockaddr_un sun;//地址信息结构体sun.sun_family=AF_UNIX;strcpy(sun.sun_path,"./mysocket");//绑定地址信息if(bind(sfd,(struct sockaddr*)&sun,sizeof(sun))==-1){perror("bind error");return -1;}printf("bind success\n");//监听if(listen(sfd,128)==-1){perror("listen error");return -1;}printf("listen error");//接收客户端发来的链接请求,并保存客户端地址信息,返回新的文件描述符用于通信struct sockaddr_un cun;socklen_t socklen=sizeof(cun);int newfd=-1;if((newfd=accept(sfd,(struct sockaddr*)&cun,&socklen))==-1){perror("accept error");return -1;}puts("已接受新客户端连接");char rbuf[128]="";while(1){bzero(rbuf,sizeof(rbuf));//接收客户端信息recv(newfd,rbuf,sizeof(rbuf),0);printf("[%s]:%s\n",cun.sun_path,rbuf);strcat(rbuf,"*_*");//回复消息send(newfd,rbuf,strlen(rbuf),0);printf("发送成功\n");}close(sfd);close(newfd);return 0;
}

 2.客户端代码

#include<myhead.h>int main(int argc, const char *argv[])
{int cfd=socket(AF_UNIX,SOCK_STREAM,0);if(cfd==-1){perror("socket error");return -1;}if(access("./mysocket1",F_OK)==0){if(unlink("./mysocket1")==-1){perror("unlink error");return -1;}}struct sockaddr_un cun;//客户端地址信息cun.sun_family=AF_UNIX;strcpy(cun.sun_path,"./mysocket1");if(bind(cfd,(struct sockaddr*)&cun,sizeof(cun))==-1)//绑定客户端{perror("bind error");return -1;}printf("bind success\n");struct sockaddr_un sun;//服务器地址信息sun.sun_family=AF_UNIX;strcpy(sun.sun_path,"./mysocket");if(connect(cfd,(struct sockaddr*)&sun,sizeof(sun))==-1)//连接服务器{perror("connet error");return -1;}printf("connet success\n");char wbuf[128]="";while(1){bzero(wbuf,sizeof(wbuf));printf("请输入>>>");fgets(wbuf,sizeof(wbuf),stdin);wbuf[strlen(wbuf)-1]=0;send(cfd,wbuf,strlen(wbuf),0);printf("发送成功\n");if(strcmp(wbuf,"quit")==0){break;}bzero(wbuf,sizeof(wbuf));recv(cfd,wbuf,sizeof(wbuf),0);printf("收到消息为:%s\n",wbuf);}close(cfd);return 0;
}

运行:

四、报式域套接字 (基于udp)的服务器、客户端实现。

1.服务器代码

#include<myhead.h>int main(int argc, const char *argv[])
{int sfd=socket(AF_UNIX,SOCK_DGRAM,0);//创建基于udp创建域套接字if(sfd==-1){perror("socket error");return -1;}if(access("./linux1",F_OK)==0)//检查文件是否存在如果存在则删除{if(unlink("./linux1")==-1){perror("unlink error");return -1;}}struct sockaddr_un sun;//设置服务器地址sun.sun_family=AF_UNIX;strcpy(sun.sun_path,"./linux1");//绑定服务器自身地址信息if(bind(sfd,(struct sockaddr*)&sun,sizeof(sun))==-1){perror("bind error");return -1;}printf("bind success\n");char rbuf[128]="";struct sockaddr_un cun;//客户端地址信息容器socklen_t socklen=sizeof(cun);while(1){bzero(rbuf,sizeof(rbuf));//接收客户端消息并且保存客户端地址recvfrom(sfd,rbuf,sizeof(rbuf),0,(struct sockaddr*)&cun,&socklen);printf("收到消息为:%s\n",rbuf);strcat(rbuf,"*_*");//给发来消息的客户端回复if(sendto(sfd,rbuf,strlen(rbuf),0,(struct sockaddr*)&cun,sizeof(cun))==-1){perror("sendto error");return -1;}}close(sfd);return 0;
}

2.客户端代码

#include<myhead.h>int main(int argc, const char *argv[])
{int cfd=socket(AF_UNIX,SOCK_DGRAM,0);//创建域套接字 传输方式udpif(cfd==-1){perror("socket error");return -1;}printf("cfd=%d\n",cfd);if(access("./linux2",F_OK)==0){if(unlink("./linux2")==-1){perror("unlink error");return -1;}}	struct sockaddr_un cun;//客户端自身地址信息cun.sun_family=AF_UNIX;strcpy(cun.sun_path,"./linux2");//绑定地址信息 如果要从服务器接收消息则必须绑定 否则系统不会自动绑定 服务器接收的地址为空 无法发来消息if(bind(cfd,(struct sockaddr*)&cun,sizeof(cun))==-1){perror("bind error");return -1;}printf("bind success\n");char wbuf[128]="";struct sockaddr_un sun;//保存服务器地址sun.sun_family=AF_UNIX;strcpy(sun.sun_path,"./linux1");while(1){bzero(wbuf,sizeof(wbuf));printf("请输入>>>");fgets(wbuf,sizeof(wbuf),stdin);wbuf[strlen(wbuf)-1]=0;//发送消息sendto(cfd,wbuf,sizeof(wbuf),0,(struct sockaddr*)&sun,sizeof(sun));printf("发送成功\n");bzero(wbuf,sizeof(wbuf));recvfrom(cfd,wbuf,sizeof(wbuf),0,NULL,NULL);//接收消息,因为前面已经有了服务器地址信息 所以此处可以不接收printf("收到消息:%s\n",wbuf);}close(cfd);return 0;
}

运行:

思维导图:

这篇关于42、网络编程/多点通信和域套接字通信模型20240304的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/775781

相关文章

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

C# async await 异步编程实现机制详解

《C#asyncawait异步编程实现机制详解》async/await是C#5.0引入的语法糖,它基于**状态机(StateMachine)**模式实现,将异步方法转换为编译器生成的状态机类,本... 目录一、async/await 异步编程实现机制1.1 核心概念1.2 编译器转换过程1.3 关键组件解析

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁