• linux中C语言发送广播报文


    2. 指令的解决方法:
    oute add -net 255.255.255.255 netmask 255.255.255.255 dev eth0 metric 1
    或者
    route add -host 255.255.255.255 dev eth0
     
    需要用到函数:setsockopt();
     
    setsockopt()函数,用于任意类型、任意状态套接口的设置选项值。尽管在不同协议层上存在选项,但本函数仅定义了最高的“套接口”层次上的选项。
    #include <sys/types.h>
    #include <sys/socket.h>
    函数原型:
    int setsockopt(int sockfd, int level, int optname,const void *optval, socklen_t optlen);
    sockfd:标识一个套接口的描述字。
    level:选项定义的层次;支持SOL_SOCKET、IPPROTO_TCP、IPPROTO_IP和IPPROTO_IPV6。
    optname:需设置的选项。
    optval:指针,指向存放选项待设置的新值的缓冲区
    optlen:optval缓冲区长度。
     
    example:
    1. #include<stdio.h>  
    2. #include<stdlib.h>  
    3. #include<string.h>  
    4. #include<sys/types.h>  
    5. #include<sys/socket.h>  
    6. #include<sys/wait.h>  
    7. #include<netinet/in.h>  
    8. #include<arpa/inet.h>  
    9. #include<errno.h>  
    10. int main(){  
    11.     char msg[128] = "I am broadCast message from server!";  
    12.     int brdcFd;  
    13.     if((brdcFd = socket(PF_INET, SOCK_DGRAM, 0)) == -1){  
    14.         printf("socket fail ");  
    15.         return -1;  
    16.     }  
    17.     int optval = 1;//这个值一定要设置,否则可能导致sendto()失败  
    18.     setsockopt(brdcFd, SOL_SOCKET, SO_BROADCAST | SO_REUSEADDR, &optval, sizeof(int));  
    19.     struct sockaddr_in theirAddr;  
    20.     memset(&theirAddr, 0, sizeof(struct sockaddr_in));  
    21.     theirAddr.sin_family = AF_INET;  
    22.     theirAddr.sin_addr.s_addr = inet_addr("255.255.255.255");  
    23.     theirAddr.sin_port = htons(4001);  
    24.     int sendBytes;  
    25.     if((sendBytes = sendto(brdcFd, msg, strlen(msg), 0,  
    26.             (struct sockaddr *)&theirAddr, sizeof(struct sockaddr))) == -1){  
    27.         printf("sendto fail, errno=%d ", errno);  
    28.         return -1;  
    29.     }  
    30.     printf("msg=%s, msgLen=%d, sendBytes=%d ", msg, strlen(msg), sendBytes);  
    31.     close(brdcFd);  
    32.     return 0;  
    33. }
     
    SOL_SOCKET注解:
    第一个参数socket是套接字描述符。第二个参数level是被设置的选项的级别,如果想要在套接字级别上设置选项,就必须把level设置为 SOL_SOCKET。 option_name指定准备设置的选项,option_name可以有哪些取值,这取决于level,以Linux 2.6内核为例(在不同的平台上,这种关系可能会有不同),在套接字级别上(SOL_SOCKET),option_name可以有以下取 值:
     
    1.     SO_DEBUG,打开或关闭调试信息。
     
        当option_value不等于0时,打开调试信息,否则,关闭调试信息。它实际所做的工作是在sock->sk->sk_flag中置 SOCK_DBG(第10)位,或清SOCK_DBG位。
    1.     SO_REUSEADDR,打开或关闭地址复用功能。
     
        当option_value不等于0时,打开,否则,关闭。它实际所做的工作是置sock->sk->sk_reuse为1或0。
    1.     SO_DONTROUTE,打开或关闭路由查找功能。
     
        当option_value不等于0时,打开,否则,关闭。它实际所做的工作是在sock->sk->sk_flag中置或清 SOCK_LOCALROUTE位。
    1.     SO_BROADCAST,允许或禁止发送广播数据。
     
        当option_value不等于0时,允许,否则,禁止。它实际所做的工作是在sock->sk->sk_flag中置或清 SOCK_BROADCAST位。
    1.     SO_SNDBUF,设置发送缓冲区的大小。
     
        发送缓冲区的大小是有上下限的,其上限为256 * (sizeof(struct sk_buff) + 256),下限为2048字节。该操作将sock->sk->sk_sndbuf设置为val * 2,之所以要乘以2,是防
    大数据量的发送,突然导致缓冲区溢出。最后,该操作完成后,因为对发送缓冲的大小 作了改变,要检查sleep队列,如果有进程正在等待写,将它们唤醒。
    1.     SO_RCVBUF,设置接收缓冲区的大小。
     
        接收缓冲区大小的上下限分别是:256 * (sizeof(struct sk_buff) + 256)和256字节。该操作将sock->sk->sk_rcvbuf设置为val * 2。
    1.     SO_KEEPALIVE,套接字保活。
     
        如果协议是TCP,并且当前的套接字状态不是侦听(listen)或关闭(close),那么,当option_value不是零时,启用TCP保活定时 器,否则关闭保活定时器。对于所有协议,该操
    作都会根据option_value置或清 sock->sk->sk_flag中的 SOCK_KEEPOPEN位。
    1.     SO_OOBINLINE,紧急数据放入普通数据流。
     
        该操作根据option_value的值置或清sock->sk->sk_flag中的SOCK_URGINLINE位。
    1.     SO_NO_CHECK,打开或关闭校验和。
     
        该操作根据option_value的值,设置sock->sk->sk_no_check。
    1.     SO_PRIORITY,设置在套接字发送的所有包的协议定义优先权。Linux通过这一值来排列网络队列。
     
        这个值在0到6之间(包括0和6),由option_value指定。赋给sock->sk->sk_priority。
    1.     SO_LINGER,如果选择此选项, close或 shutdown将等到所有套接字里排队的消息成功发送或到达延迟时间后>才会返回. 否则, 调用将立即返回。
     
        该选项的参数(option_value)是一个linger结构:
            struct linger {
                int   l_onoff;    /* 延时状态(打开/关闭) */
                int   l_linger;   /* 延时多长时间 */
            };
    如果linger.l_onoff值为0(关闭),则清 sock->sk->sk_flag中的SOCK_LINGER位;否则,置该位,并赋sk->sk_lingertime值为 linger.l_linger。
    1.     SO_PASSCRED,允许或禁止SCM_CREDENTIALS 控制消息的接收。
     
        该选项根据option_value的值,清或置sock->sk->sk_flag中的SOCK_PASSCRED位。
    1.     SO_TIMESTAMP,打开或关闭数据报中的时间戳接收。
     
        该选项根据option_value的值,清或置sock->sk->sk_flag中的SOCK_RCVTSTAMP位,如果打开,则还需 设sock->sk->sk_flag中的SOCK_TIMESTAMP位,同时,将全局变量
    netstamp_needed加1。
    1.     SO_RCVLOWAT,设置接收数据前的缓冲区内的最小字节数。
     
        在Linux中,缓冲区内的最小字节数是固定的,为1。即将sock->sk->sk_rcvlowat固定赋值为1。
    1.     SO_RCVTIMEO,设置接收超时时间。
     
        该选项最终将接收超时时间赋给sock->sk->sk_rcvtimeo。
    1.     SO_SNDTIMEO,设置发送超时时间。
     
        该选项最终将发送超时时间赋给sock->sk->sk_sndtimeo。
    1.     SO_BINDTODEVICE,将套接字绑定到一个特定的设备上。
     
        该选项最终将设备赋给sock->sk->sk_bound_dev_if。
    1.     SO_ATTACH_FILTER和SO_DETACH_FILTER。  
  • 相关阅读:
    CSS旧版flex及兼容
    深入理解CSS弹性盒模型flex
    CSS文本方向
    文本溢出text-overflow和文本阴影text-shadow
    深入理解CSS中的空白符和换行
    CSS中常见的6种文本样式
    理解CSS相对定位和固定定位
    CSS绝对定位的应用
    深入理解CSS绝对定位absolute
    深入理解CSS中的margin负值
  • 原文地址:https://www.cnblogs.com/yaox/p/6623494.html
Copyright © 2020-2023  润新知