Linux上接收广播

在windows上接收广播比较简单:使用setsockopt结合SO_BROADAST即可。但是同样的代码不能在linux上获得同样的效果。

使用tcpdump监听,确实收到了广播包:

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAbGlqaV9kaWdpdGFs,size_19,color_FFFFFF,t_70,g_se,x_16

stackoverflow上的解法:

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAbGlqaV9kaWdpdGFs,size_20,color_FFFFFF,t_70,g_se,x_16 

 

修改代码,增加 INADDR_BROADCAST一项:

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

int main(void)
{
    int sck = socket(AF_INET,SOCK_DGRAM,0);
    char arrRcv[1024];
    if(sck >=0){
        int iOn = 1;
        std::cout<<"join brdcst"<<setsockopt(sck, SOL_SOCKET, SO_BROADCAST, &iOn, sizeof(int))
                <<std::endl;

        struct sockaddr_in local_addr;
        memset(&local_addr, 0, sizeof(local_addr));
        local_addr.sin_family=AF_INET;
        local_addr.sin_addr.s_addr=htonl(INADDR_BROADCAST);//have to do this otherwise can't recv broadcast on linux
        local_addr.sin_port=htons(9987);
        int err = ::bind(sck,(struct sockaddr*)&local_addr,sizeof(local_addr));
        if(0 == err)
        {
            std::cout<<"bind succ"<<std::endl;
            int iRcvLen = recv(sck, arrRcv, 1024, 0);
            if(iRcvLen > 0){
                std::cout<<iRcvLen<<std::endl;
            }
        }
    }

    return 0;
}

收到数据。

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值