实验环境

linux

注意:

使用UDP广播,是客户端发送广播消息,服务器端接收消息。实际上是客户端探测局域网中可用服务器的一种手段。客户端发送,服务器端接收,千万不能弄混淆!!!

为了避免混淆,本文不使用client、server字眼。而使用send,recv

构建send_broadcast.c。发送广播消息,并打印接收端的IP和端口,退出时发送"done"消息

流程:创建一个socket,并用setscokopt函数声明这是一个broadcast类型的socket,然后通过这个socket向INADDR_BROADCAST("255.255.255.255")发送消息。

#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h> #define PORT 1234
#define BUFFER_SIZE 100 int32_t main()
{
char msg[BUFFER_SIZE] = "I am a broadcast message";
int32_t nb = ;
struct sockaddr_in addrto;
int32_t nlen=sizeof(addrto); int32_t sockfd = -;
if ((sockfd = socket(AF_INET, SOCK_DGRAM, )) == -)
{
perror("create socket failed\n");
return -;
} const int opt = ;
//设置该套接字为广播类型,
nb = setsockopt(sockfd, SOL_SOCKET, SO_BROADCAST | SO_REUSEADDR, &opt, sizeof(opt));
if(nb == -)
{
perror("set socket error...\n");
return -;
} /**< 接收者地址结构 */
bzero(&addrto, sizeof(struct sockaddr_in));
addrto.sin_family = AF_INET;
addrto.sin_addr.s_addr = htonl(INADDR_BROADCAST);
addrto.sin_port = htons(PORT); int ret = sendto(sockfd, msg, BUFFER_SIZE, , (struct sockaddr*)&addrto, nlen);
if (ret < )
{
perror("send error.\n");
} /**< 打印接收者的IP和端口号 */
printf("recver's ip is %s, port is %d.\n", inet_ntoa(addrto.sin_addr), htons(addrto.sin_port)); bzero(msg, BUFFER_SIZE);
memcpy(msg, "done", ); sendto(sockfd, msg, BUFFER_SIZE, , (struct sockaddr*)&addrto, nlen); printf("Done\n");
return ;
}

构建recv_broadcast.c 接收广播消息,打印发送端的IP和端口号,在接收到done后停止并退出

流程:创建一个socket并绑定INADDR_ANY的本地地址,接收消息

#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h> #define PORT 1234
#define BUFFER_SIZE 100 int32_t main()
{
struct sockaddr_in addrto; struct sockaddr_in from;
int32_t listenfd = -;
int32_t len = sizeof(from);
char recvbuf[BUFFER_SIZE]; if ((listenfd = socket(AF_INET, SOCK_DGRAM, )) == -)
{
perror("create socket failed\n");
return -;
} bzero(&addrto, sizeof(struct sockaddr_in));
bzero(&from, sizeof(struct sockaddr_in));
addrto.sin_family = AF_INET;
addrto.sin_port = htons(PORT);
addrto.sin_addr.s_addr = htonl(INADDR_ANY); const int opt = ;
int32_t nb = setsockopt(listenfd, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));
if(nb == -)
{
perror("set socket error...\n");
return -;
} /**< 绑定自己的地址 */
if (bind(listenfd, (struct sockaddr *)&addrto, len) == -)
{
perror("bind error\n");
return -;
} while ()
{
//从广播地址接收消息
int ret = recvfrom(listenfd, recvbuf, BUFFER_SIZE, , (struct sockaddr*)&from, &len);
if (ret > )
{
recvbuf[ret] = '\0';
printf("receive messgse:%s\n", recvbuf);
if (!strcmp("done", recvbuf))
{
break;
}
}
else
{
perror("recv error.\n"); }
bzero(recvbuf, BUFFER_SIZE); /**< 打印发送者的ip和端口号 */
printf("sender's ip is %s, port is %d.\n", inet_ntoa(from.sin_addr), htons(from.sin_port));
} close(listenfd);
printf("Done\n");
return ;
}

Makefile

all:sender recver
sender:
gcc send_broadcast.c -o sender recver:
gcc recv_broadcast.c -o recver clean:
rm -rf sender recver

UDP广播的客户端和服务器端的代码设计的更多相关文章

  1. 基于UDP的客户端和服务器端的代码设计

    实验平台 linux 实验内容 编写UDP服务器和客户端程序,客户端发送消息,服务器接收消息,并打印客户端的IP地址和端口号. 实验原理 UDP是无需连接的通信,其主要实现过程如下: 同样,我们可以按 ...

  2. 基于TCP的客户端和服务器端的代码设计

    实验平台 linux 实验内容 编写TCP服务器和客户端程序,程序运行时服务器等待客户端连接.一旦连接成功,服务器显示客户端的IP地址和端口号,并向客户端发送字符串 实验原理 TCP是面向连接的通信, ...

  3. C/S模型:TCP,UDP构建客户端和服务器端(BIO实现

    Java中提供了socket编程来构建客户端和服务器端 TCP构建服务器端的步骤:(1)bind:绑定端口号(2)listen:监听客户端的连接请求(3)accept:返回和客户端连接的实例(4)re ...

  4. Java实现UDP之Echo客户端和服务端

    Java实现UDP之Echo客户端和服务端 代码内容 采用UDP协议编写服务器端代码(端口任意) 编写客户机的代码访问该端口 客户机按行输入 服务器将收到的字符流和接收到的时间输出在服务器consol ...

  5. UDP广播 与 TCP客户端 --服务端

    随着倒计时的响声,自觉无心工作,只想为祖国庆生. 最近有遇到过这样一个问题,将摄像头识别的行人,车辆实时显示在客户端中.有提供接口,会以Json的数据的形式将实时将识别的对象进行Post提交.所以我们 ...

  6. 牛客网Java刷题知识点之TCP、UDP、TCP和UDP的区别、socket、TCP编程的客户端一般步骤、TCP编程的服务器端一般步骤、UDP编程的客户端一般步骤、UDP编程的服务器端一般步骤

    福利 => 每天都推送 欢迎大家,关注微信扫码并加入我的4个微信公众号:   大数据躺过的坑      Java从入门到架构师      人工智能躺过的坑         Java全栈大联盟   ...

  7. android客户端从服务器端获取json数据并解析的实现代码

    今天总结一下android客户端从服务器端获取json数据的实现代码,需要的朋友可以参考下   首先客户端从服务器端获取json数据 1.利用HttpUrlConnection /** * 从指定的U ...

  8. 在vs code中使用ftp-sync插件实现客户端与服务器端代码的同步

    在vs code中使用ftp-sync插件实现客户端与服务器端代码的同步 下载安装 vscode-ftp-sync 插件. 安装方法1. Ctrl+Shift+P 输入 ext install [插件 ...

  9. (转)android客户端从服务器端获取json数据并解析的实现代码

    今天总结一下android客户端从服务器端获取json数据的实现代码,需要的朋友可以参考下       首先客户端从服务器端获取json数据 1.利用HttpUrlConnection   复制代码 ...

随机推荐

  1. Struts2-学习笔记系列(10)-自定义类型转换

    注意name=user和对应action中的实例名称一致 这些代码是写在HTML文件中的 <s:form action="login"> <s:textfield ...

  2. 【python实现卷积神经网络】优化器的实现(SGD、Nesterov、Adagrad、Adadelta、RMSprop、Adam)

    代码来源:https://github.com/eriklindernoren/ML-From-Scratch 卷积神经网络中卷积层Conv2D(带stride.padding)的具体实现:https ...

  3. 大数据及hadoop简要概念

    大数据 大数据简要概念 指无法在一定时间范围内用常规软件工具进行捕捉.管理和处理的数据集合.需要新处理模式,才能具有更强的决策力.洞察发现力和流程优化能力的海量.高增长率和多样化的信息资产. 大数据作 ...

  4. vue2.x学习笔记(五)

    接着前面的内容:https://www.cnblogs.com/yanggb/p/12571062.html. 计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.如果在模板中放入太 ...

  5. Spark SQL源码解析(二)Antlr4解析Sql并生成树

    Spark SQL原理解析前言: Spark SQL源码剖析(一)SQL解析框架Catalyst流程概述 这一次要开始真正介绍Spark解析SQL的流程,首先是从Sql Parse阶段开始,简单点说, ...

  6. Os-hackNos-1靶机过关记录

    靶机地址:172.16.1.198(或112)  kali地址:172.16.1.108 1 信息收集 靶机界面如下 简单查看 OS:Ubuntu Web:Apache2.4.18 尝试端口扫描 开放 ...

  7. Linux学习笔记(九)Vim文本编辑器的使用

    Vim文本编辑器的使用 Vim的工作模式 1.命令模式 2.输入模式 3.编辑模式 进入Vim 1.使用Vim打开文件 2.直接进入指定位置 Vim基本命令 1.插入命令 2.光标移动命令 3.使用V ...

  8. tf.keras的模块

          

  9. 关于go的入门书籍——go自学的序

    说实话,许世伟的<GO语言编程>,承载的心血是轻易可见的.但是我更喜欢那种工具书,就是简单说明他干嘛她干嘛,就能干嘛干嘛··· 比如读张晏关于<取代Apache的高性能Web服务器& ...

  10. 解释BOM头和去掉方法

    http://www.thinkphp.cn/topic/2592.html 以上是叫你去掉bom头的,因为有些文件加载不出来就是window会以记事本的形式打开,然后默认给我们加了了bom头,有些文 ...