linux 廣播問題errno==13定位

原因分析:

沒有設置socket的廣播SO_BROADCAST屬性,或者設置失敗卻想當然的認爲是成功。這時sendto數據返回-1,errno等於13.


1、設置SO_BROADCAST失敗,windows上xp是可以成功的

    bool bOptVal= 1;
    int n = setsockopt(sock, SOL_SOCKET, SO_BROADCAST, (const char*)&bOptVal, sizeof(bool));



2、設置SO_BROADCAST成功

    int bOptVal= 1;
    int n = setsockopt(sock, SOL_SOCKET, SO_BROADCAST, (const char*)&bOptVal, sizeof(int));

 

// 附錄:代碼

#include <stdio.h>

#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <errno.h>
#include <stdlib.h>

int main(int argc, char **argv)
{
    int sock = 0;


    if (argc < 2) {
        printf("Usage: %s local_address destination_address\n", argv[0]);
        exit(1);
    }


    sock = socket(AF_INET, SOCK_DGRAM, 0);
    if (sock <= 0) {
        perror("socket");
        return -1;
    }


    int bOptVal= 1;
    int n = setsockopt(sock, SOL_SOCKET, SO_BROADCAST, (const char*)&bOptVal, sizeof(int));
    printf("setsockopt return %d !\n",n);


    struct sockaddr_in local_addr;
    local_addr.sin_family = AF_INET;
    local_addr.sin_port = htons(1234);
    local_addr.sin_addr.s_addr = inet_addr(argv[1]);
    int ret = bind(sock, (struct sockaddr *) &local_addr, sizeof(local_addr));
    if (ret < 0) {
        perror("bind");
        return -1;
    }
    
    struct sockaddr_in remote_addr;
    remote_addr.sin_family = AF_INET;
    remote_addr.sin_port = htons(1234);
    remote_addr.sin_addr.s_addr = inet_addr(argv[2]);
    ret = sendto(sock, "blah", 4, 0, (struct sockaddr *)&remote_addr, sizeof(remote_addr));
    if (ret < 0) {
        printf("sendto() returned negative, errno: %d/%m\n", errno);
    }
    else {
        printf("sendto() returned %d\n", ret);        
    }


    return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章