Linux网络编程常用头文件解释
sys/types.h:數據類型定義
sys/socket.h:提供socket函數及數據結構
netinet/in.h:定義數據結構sockaddr_in
arpa/inet.h:提供IP地址轉換函數
netdb.h:提供設置及獲取域名的函數
sys/ioctl.h:提供對I/O控制的函數
sys/poll.h:提供socket等待測試機制的函數
其他在網絡程序中常見的頭文件?
unistd.h:提供通用的文件、目錄、程序及進程操作的函數
errno.h:提供錯誤號errno的定義,用于錯誤處理
fcntl.h:提供對文件控制的函數
time.h:提供有關時間的函數
crypt.h:提供使用DES加密算法的加密函數
pwd.h:提供對/etc/passwd文件訪問的函數
shadow.h:提供對/etc/shadow文件訪問的函數
pthread.h:提供多線程操作的函數
signal.h:提供對信號操作的函數
sys/wait.h、sys/ipc.h、sys/shm.h:提供進程等待、進程間通訊(IPC)及共享內存的函數
?
建議: 在編寫網絡程序時,可以直接使用下面這段頭文件代碼
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netdb.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <errno.h>
#include <malloc.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <sys/ioctl.h>
#include <stdarg.h>
#include <fcntl.h>
#include <fcntl.h>
涉及到用戶權限及密碼驗證問題時加入如下語句:
#include <shadow.h>
#include <crypt.h>
#include <pwd.h>?
需要注意的是,應該在編譯時鏈接加密算法庫,即增加編譯選項:
-lcrypt
涉及到文件及時間操作加入如下語句:?
#include <sys/time.h>
#include <utime.h>
#include <time.h>
#include <sys/stat.h>
#include <sys/file.h>
涉及到多進程操作時加入如下語句:?
#include <sys/wait.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <signal.h>
涉及到多線程操作時加入如下語句:?
#include <pthread.h>
#include <sys/poll.h>
需要注意的是,應該在編譯時鏈接線程庫,即增加編譯選項:-lthread
?
?
?
netinet/if_ether.h?? ether_arp的數據結構
netinet/ether.h??? 以太禎的網絡字節和ascii字節的轉換,包括ether_ntoa(),ether_aton這樣的函數定義
netinet/ip.h?? 這個頭文件和linux/ip.h似乎很相似,也有iphdr的數據結構,同時還包括了timestamp結構,我的理解是,linux文件夾下的 ip.h是linux黑客編寫的ip頭文件,而這個則是gnu一開始就定義的頭文件,同時還包括了bsd中的ipheader結構定義。同理的還有該目錄下的tcp.h等文件
linux/ip.h?? iphdr的數據結構,以及一些ip層的數據定義,同理的還有tcp.h,udp.h等等
linux/if.h??? 主要的socket頭文件,似乎修改自unix的if.h,定義了網卡的接口信息的宏,例如IFF_UP.另外有數個重要的interface的數據結構定義,包括ifreq,ifconf,ifmap
linux/if_packet.h??? 原始數據包的數據結構定義,包括sockaddr_pkt,sockaddr_ll,想接收原始數據包的不能錯過這個文件。同理的還有if_ppp.h,if_tun.h等等
netinet/in.h??? 這個文件作的事情就多了。端口宏定義,著名ip(比如loopback),結構sockaddr_in,網絡字節轉換(ntoh,hton。。。。)。。。反正太多了,沒事的話就把這個文件加到頭文件包含里吧
netdb.h??? 文件如其名,包括結構hostent(主機環境),獲得主機的信息的幾個函數(gethostbyname)。似乎這個就是定義主機的各項環境,例如hostname等等
net/bpf.h? berkeley的數據包過濾頭文件,想用bpf進行包過濾的要重視一下這個文件
net/ethernet.h 包括幾個以太網的數據結構,ether_addr(mac幀結構),ether_header(以太幀的頭部)
?
?
-------------------------------
<sys/types.h>????????????????????//primitive system data types(包含很多類型重定義,如pid_t、int8_t等)???
<sys/socket.h>???????? //與套接字相關的函數聲明和結構體定義,如socket()、bind()、connect()及struct sockaddr的定義等
<sys/ioctl.h>???????????? //I/O控制操作相關的函數聲明,如ioctl()
<stdlib.h>?????????????????? //某些結構體定義和宏定義,如EXIT_FAILURE、EXIT_SUCCESS等
<netdb.h>??????????????????//某些結構體定義、宏定義和函數聲明,如struct hostent、struct servent、gethostbyname()、gethostbyaddr()、herror()等
<arpa/inet.h>?????????? //某些函數聲明,如inet_ntop()、inet_ntoa()等
<netinet/in.h>??????????//某些結構體聲明、宏定義,如struct sockaddr_in、PROTO_ICMP、INADDR_ANY等
?
?
------------------------------
linux下socket編寫常用頭文件
?
#include <sys/socket.h>?? //connect,send,recv,setsockopt等
#include <sys/types.h>?? ???
#include <netinet/in.h>???? // sockaddr_in,?"man 7 ip"?,htons
#include <poll.h>?? ?? ??? ?? //poll,pollfd
#include <arpa/inet.h>?? //inet_addr,inet_aton
#include <unistd.h>??????? //read,write
#include <netdb.h>?? ?? ?? //gethostbyname
#include <error.h> ??? ??? //perror
#include <stdio.h>
#include <errno.h>?? ?? ?? //errno
#include <string.h>??? ????? // memset
#include <string>
#include <iostream>
?
?
?
1.1.??????<sys/types.h>
primitive system data types(包含很多類型重定義,如pid_t、int8_t等)
1.2.??????<sys/socket.h>
//與套接字相關的函數聲明和結構體定義,如socket()、bind()、connect()及struct sockaddr的定義等
?
int setsockopt(int s,int level,int optname,const void *optval,,socklen_toptlen);
用來設置參數s所指定的socket狀態。參數level代表欲設置的網絡層,一般設成SOL_SOCKET以存取socket層。參數optname代表欲設置的選項,有下列幾種數值:
SO_DEBUG打開或關閉排錯模式
SO_REUSEADDR允許在bind()過程中本地地址可重復使用
SO_TYPE返回socket形態。
SO_ERROR返回socket已發生的錯誤原因
SO_DONTROUTE送出的數據包不要利用路由設備來傳輸。
SO_BROADCAST使用廣播方式傳送
SO_SNDBUF設置送出的暫存區大小
SO_RCVBUF設置接收的暫存區大小
SO_KEEPALIVE定期確定連線是否已終止。
SO_OOBINLINE當接收到OOB?數據時會馬上送至標準輸入設備
SO_LINGER確保數據安全且可靠的傳送出去。
?
optval代表欲設置的值,參數optlen則為optval的長度。
?
成功則返回0,若有錯誤則返回-1,錯誤原因存于errno。
EBADF參數s并非合法的socket處理代碼。
ENOTSOCK參數s為一文件描述詞,非socket。
ENOPROTOOPT參數optname指定的選項不正確。
EFAULT參數optval指針指向無法存取的內存空間。
?
?
getsockopt(取得socket狀態)
int getsockopt(int s,int level,int optname,void* optval,socklen_t*optlen);
getsockopt()會將參數s所指定的socket狀態返回。
參數:
optname代表欲取得何種選項狀態
optval則指向欲保存結果的內存地址
optlen則為該空間的大小
level、optname請參考setsockopt()
成功則返回0,若有錯誤則返回-1,錯誤原因存于errno
EBADF參數s?并非合法的socket處理代碼
ENOTSOCK參數s為一文件描述詞,非socket
ENOPROTOOPT參數optname指定的選項不正確
EFAULT參數optval指針指向無法存取的內存空間
?
1.3.??????<sys/ioctl.h>
//I/O控制操作相關的函數聲明,如ioctl()
1.4.??????<stdlib.h>
/某些結構體定義和宏定義,如EXIT_FAILURE、EXIT_SUCCESS等
1.5.??????<netdb.h>
定義主機的各項環境,包括結構hostent(主機環境), hostname,獲得主機的信息的幾個函數(gethostbyname),如:gethostbyname()、gethostbyaddr()、herror()
?
某些結構體定義、宏定義,如struct hostent、struct servent、等
?
voidsetprotoent (int stayopen);
用來打開/etc/protocols,如果參數stayopen值為1,則接下來的getprotobyname()或getprotobynumber()將不會自動關閉此文件
?
void endprotoent(void);
用來關閉由getprotoent()打開的文件。
?
void setservent(int stayopen);
用來打開/etc/services,如果參數stayopen值為1,則接下來的getservbyname()或getservbyport()將補回自動關閉文件。
void endservent(void);
用來關閉由getservent()所打開的文件。
1.6.??????<unistd.h>
read,write,close
1.7.??????<poll.h>
//poll,pollfd
1.8.??????<net/ethernet.h>
包括幾個以太網的數據結構,ether_addr(mac幀結構),ether_header(以太幀的頭部)
?
1.9.??????<netinet/in.h>
某些結構體聲明、宏定義,如struct sockaddr_in、PROTO_ICMP、INADDR_ANY等
?
1.10.?<netinet/if_ether.h>??
ether_arp的數據結構
?
1.11.?<netinet/ether.h>???
以太禎的網絡字節和ascii字節的轉換,包括ether_ntoa(),ether_aton這樣的函數定義
?
1.12.?<netinet/ip.h>
這個頭文件和linux/ip.h似乎很相似,也有iphdr的數據結構,同時還包括了timestamp結構,我的理解是,linux文件夾下的?ip.h是linux黑客編寫的ip頭文件,而這個則是gnu一開始就定義的頭文件,同時還包括了bsd中的ipheader結構定義。同理的還有該目錄下的tcp.h等文件
?
1.13.?<linux/ip.h>
?? iphdr的數據結構,以及一些ip層的數據定義,同理的還有tcp.h,udp.h等等
?
1.14.?<linux/if.h>
????主要的socket頭文件,似乎修改自unix的if.h,定義了網卡的接口信息的宏,例如IFF_UP.另外有數個重要的interface的數據結構定義,包括ifreq,ifconf,ifmap
?
1.15.?<linux/if_packet.h>
????原始數據包的數據結構定義,包括sockaddr_pkt,sockaddr_ll,想接收原始數據包的不能錯過這個文件。同理的還有if_ppp.h,if_tun.h等等
?
1.16.?<arpa/inet.h>
某些函數聲明,如inet_ntop()、inet_ntoa()等
總結
以上是生活随笔為你收集整理的Linux网络编程常用头文件解释的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【BAT】BAT 阶段技能汇总:全功能小
- 下一篇: 仿豌豆荚应用列表进入详情效果