关于c:Linux函数学习setsockoptgetsockopt和getsockname函数

8次阅读

共计 2843 个字符,预计需要花费 8 分钟才能阅读完成。

简介:setsockopt、getsockopt 这两个函数获取套接字一些无关选项和设置套接字无关的套接字。getsockname 是通过套接字获取套接字无关的一些信息,例如端口、协定等。

1:int setsockopt(int sockfd, int level, int optname, const void *optval, socklen_t optlen);


sock:将要被设置或者获取选项的套接字。level:选项所在的协定层。optname:须要拜访的选项名。optval:对于 getsockopt(),指向返回选项值的缓冲。对于 setsockopt(),指向蕴含新选项值的缓冲。optlen:对于 getsockopt(),作为入口参数时,选项值的最大长度。作为进口参数时,选项值的理论长度。对于 setsockopt(),现选项的长度。对于 level 和 optname 具体参数如下

level 指定管制套接字的档次. 能够取三种值:
1)SOL_SOCKET: 通用套接字选项.
2)IPPROTO_IP:IP 选项.
3)IPPROTO_TCP:TCP 选项. 

返回阐明:胜利执行时,返回 0。失败返回 -1,errno 被设为以下的某个值  
EBADF:sock 不是无效的文件形容词
EFAULT:optval 指向的内存并非无效的过程空间
EINVAL:在调用 setsockopt() 时,optlen 有效
ENOPROTOOPT:指定的协定层不能辨认选项
ENOTSOCK:sock 形容的不是套接字

optval 取得或者是设置套接字选项. 依据选项名称的数据类型进行转换 


选项名称        阐明                  数据类型
========================================================================
                        SOL_SOCKET
------------------------------------------------------------------------
SO_BROADCAST      容许发送播送数据            int
SO_DEBUG        容许调试                int
SO_DONTROUTE      不查找路由               int
SO_ERROR        取得套接字谬误             int
SO_KEEPALIVE      放弃连贯                int
SO_LINGER        提早敞开连贯              struct linger
SO_OOBINLINE      带外数据放入失常数据流         int
SO_RCVBUF        接收缓冲区大小             int
SO_SNDBUF        发送缓冲区大小             int
SO_RCVLOWAT       接收缓冲区上限             int
SO_SNDLOWAT       发送缓冲区上限             int
SO_RCVTIMEO       接管超时                struct timeval
SO_SNDTIMEO       发送超时                struct timeval
SO_REUSERADDR      容许重用本地地址和端口         int
SO_TYPE         取得套接字类型             int
SO_BSDCOMPAT      与 BSD 零碎兼容              int
========================================================================
                        IPPROTO_IP
------------------------------------------------------------------------
IP_HDRINCL       在数据包中蕴含 IP 首部          int
IP_OPTINOS       IP 首部选项               int
IP_TOS         服务类型
IP_TTL         生存工夫                int
========================================================================
                        IPPRO_TCP
------------------------------------------------------------------------
TCP_MAXSEG       TCP 最大数据段的大小           int
TCP_NODELAY       不应用 Nagle 算法             int
========================================================================

int getsockopt(int socket, int level, int option_name, void *restrict option_value, socklen_t *restrict option_len);
 性能:获取一个套接字的选项
 参数:socket:文件描述符
         level:协定档次
                        SOL_SOCKET 套接字档次
                        IPPROTO_IP ip 档次
                        IPPROTO_TCP TCP 档次
        option_name:选项的名称(套接字档次)SO_BROADCAST 是否容许发送播送信息
                        SO_REUSEADDR 是否容许重复使用本地地址
                     SO_SNDBUF 获取发送缓冲区长度
                     SO_RCVBUF 获取接收缓冲区长度    

                     SO_RCVTIMEO 获取接管超时工夫
                     SO_SNDTIMEO 获取发送超时工夫
        option_value:获取到的选项的值
        option_len:value 的长度
 返回值:胜利:0
        失败:-1

int getsockname(int sockfd, struct sockaddr *localaddr,socklen_t *addrlen); 

getsockname 能够取得一个与 socket 相干的地址。服务器端能够通过它失去相干客户端地址。而客户端也能够失去以后已连贯胜利的 socket 的 ip 和端口。对于 TCP 连贯的状况,如果不进行 bind 指定 IP 和端口,那么调用 connect 连贯胜利后,应用 getsockname 能够正确取得以后正在通信的 socket 的 IP 和端口地址。而对于 UDP 的状况,无论是在调用 sendto 之后还是收到服务器返回的信息之后调用,都无奈失去正确的 ip 地址:应用 getsockname 失去 ip 为 0,端口正确。

2:在 Tinyhttpd 中有相似的例子,如下代码

正文完
 0