实验环境

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. Vue项目添加动态浏览器头部title

    0. 直接上 预览链接 + 效果图 Vue项目添加动态浏览器头部title 1. 实现思路 ( 1 ) 从路由router里面得到组件的title ( 2 ) title存vuex (本项目已经封装h ...

  2. 28.1 api-- Object(toString equals)

    /* * String toString() : 返回该对象的字符串表示 * return getClass().getName() + "@" + Integer.toHexSt ...

  3. json === dict

    import requests import json ''' json.loads(json_str) json字符串转换成字典 json.dumps(dict) 字典转换成json字符串 ''' ...

  4. AJ整理问题之:NSTimer准确吗?

    NSTimer准确吗? 问题:NSTimer准确吗?如果不准确,怎么办? NSTimer的工作原理:假设timer每隔一段时间执行一次事件,很均匀的(例如每隔多少秒),假设在某一时刻cpu在做疯狂的大 ...

  5. Linux 下迁移 Nexus3

    Nexus3 的迁移过程还是非常简单,复制整个目录到新服务器,启动即可. 备份 在原来服务器上将 nexus3 整体目录备份即可. $ tar -zcvf nexus3.tar.gz nexus3/ ...

  6. python画图——雪花(科赫曲线)

    科赫曲线是一种分形,其形态非常像雪花,因此又被称作科赫雪花.雪花曲线. 下面是用python的turtle包让我们来实时画一个 import turtledef koch(t,n): #定义一个函数 ...

  7. SQL语句加锁分析

    背景 MySQL中SQL加锁的情况十分复杂,不同隔离级别.不同索引类型.索引是否命中的SQL加锁各不相同. 然而在分析死锁过程当中,熟知各种情况的SQL加锁是分析死锁的关键,因此需要将MySQL的各种 ...

  8. Java 网络编程 -- 基于TCP实现文件上传

    Java TCP 操作基本流程 一.创建服务器 1.指定端口, 使用serverSocket创建服务器 2.阻塞式连接 accept 3.操作:输入流 输出流 4.释放资源 二.创建客户端 1.使用S ...

  9. C#多线程(14):任务基础②

    目录 判断任务状态 再说父子任务 组合任务/延续任务 复杂的延续任务 并行(异步)处理任务 并行(同步)处理任务 并行任务的 Task.WhenAny 并行任务状态 循环中值变化问题 定时任务 Tas ...

  10. xpath爬虫实战-爬取小说斗罗大陆第四部

    爬取思路 用到的第三方库文件 lxml,requests,fake_agent 用fake_agent里的UserAgent修饰爬虫 用requests进行基本的请求 用lxml进行html的分析 用 ...