Linux網絡編程:綁定( bind )端口需要注意的問題
來源:程序員人生 發布時間:2015-03-30 08:24:49 閱讀次數:3854次
所謂綁定(bind)是指他人連接我只能通過我所綁定的端口,相當于,我買了1個手機,他人要想聯系我,必須要知道我的手機號碼,這時候候,我需要怎樣辦呢?我需要給手機插上電話卡,固定1個電話號碼,這樣他人就可以通過這個電話號碼聯系我。手機插上電話卡,固定1個電話號碼,類似于綁定(bind)的進程,綁定(bind)為了固定1個端口號,別的網絡程序就能夠找到這個端口號,找到這個端口號就可以找到這個端口號所對應的網絡利用程序。
在網絡編程里,通常都是在服務器里綁定(bind)端口,這其實不是說客戶端里不能綁定(bind)端口,但這里需要注意的是,1個網絡利用程序只能綁定1個端口( 1個套接字只能 綁定1個端口 )。
1個套接字不能同時綁定多個端口,以下:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
int main(int argc, char *argv[])
{
char server_ip[30] = "10.221.20.12";
int sockfd;
sockfd = socket(AF_INET, SOCK_DGRAM, 0); //創建UDP套接字
if(sockfd < 0)
{
perror("socket");
exit(⑴);
}
// 初始化本地網絡信息
struct sockaddr_in my_addr;
bzero(&my_addr, sizeof(my_addr));
my_addr.sin_family = AF_INET;
my_addr.sin_port = htons(8000);
my_addr.sin_addr.s_addr = htonl(INADDR_ANY);
// 第1次綁定端口8000
int err_log;
err_log = bind(sockfd, (struct sockaddr*)&my_addr, sizeof(my_addr));
if(err_log != 0)
{
perror("bind 8000");
close(sockfd);
exit(⑴);
}
// 又1次綁定別的端口9000, 會綁定失敗
my_addr.sin_port = htons(9000);
err_log = bind(sockfd, (struct sockaddr*)&my_addr, sizeof(my_addr));
if(err_log != 0)
{
perror("bind 9000");
close(sockfd);
exit(⑴);
}
close(sockfd);
return 0;
}
程序編譯運行后結果以下:

如果客戶端想綁定端口號,1定要調用發送信息函數之前綁定( bind )端口,由于在發送信息函數( sendto, 或 write ),系統會自動給當前網絡程序分配1個隨機端口號,這相當于隨機綁定了1個端口號,這里只會分配1次,以后通訊就以這個隨機端口通訊,我們再綁定端口號的話,就會綁定失敗。如果我們放在發送信息函數( sendto, 或 write )之前綁定,那樣程序將以我們綁定的端口號發送信息,不會再隨機分配1個端口號。
綁定失敗例子( UDP )以下:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
int main(int argc, char *argv[])
{
char server_ip[30] = "10.221.20.12";
int sockfd;
sockfd = socket(AF_INET, SOCK_DGRAM, 0); //創建UDP套接字
if(sockfd < 0)
{
perror("socket");
exit(⑴);
}
struct sockaddr_in dest_addr;
bzero(&dest_addr, sizeof(dest_addr));
dest_addr.sin_family = AF_INET;
dest_addr.sin_port = htons(8080); //
服務器的端口
inet_pton(AF_INET, server_ip, &dest_addr.sin_addr);
char send_buf[512] = "this is for test";
// 如果前面沒有綁定端口,sendto()系統會隨機分配1個端口
sendto(sockfd, send_buf, strlen(send_buf), 0, (struct sockaddr*)&dest_addr, sizeof(dest_addr));//發送數據
// 初始化本地網絡信息
struct sockaddr_in my_addr;
bzero(&my_addr, sizeof(my_addr));
my_addr.sin_family = AF_INET;
my_addr.sin_port = htons(8000);
my_addr.sin_addr.s_addr = htonl(INADDR_ANY);
// sendto()后面綁定端口,綁定失敗
int err_log;
err_log = bind(sockfd, (struct sockaddr*)&my_addr, sizeof(my_addr));
if(err_log != 0)
{
perror("bind 8000");
close(sockfd);
exit(⑴);
}
close(sockfd);
return 0;
}
程序編譯運行后結果以下:

源代碼下載請點此處。
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈