程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> Linux收集編程之UDP Socket法式示例

Linux收集編程之UDP Socket法式示例

編輯:關於C++

Linux收集編程之UDP Socket法式示例。本站提示廣大學習愛好者:(Linux收集編程之UDP Socket法式示例)文章只能為提供參考,不一定能成為您想要的結果。以下是Linux收集編程之UDP Socket法式示例正文


在收集傳輸協定中,TCP協定供給的是一種靠得住的,龐雜的,面向銜接的數據流(SOCK_STREAM)傳輸辦事,它經由過程三段式握手進程樹立銜接。TCP有一種“重傳確認”機制,即吸收端收到數據後要收回一個確定確認的旌旗燈號,發送端假如收到吸收端確定確認的旌旗燈號,就會持續發送其他的數據,假如沒有,它就會從新發送。

絕對而言,UDP協定則是一種無銜接的,弗成靠的數據報(SOCK_DGRAM)傳輸辦事。應用UDP套接口不消樹立銜接,辦事端在挪用socket()生成一個套接字並挪用bind()綁定端口後便可以停止通訊(recvfrom函數和sendto函數)了;客戶端在用socket()生成一個套接字後便可以向辦事端地址發送和吸收數據了。

此處須要特殊留意:TCP應用的是流套接字(SOCK_STREAM),UDP應用的是數據報套接字(SOCK_DGRAM)

UDP套接字編程典范:

server端代碼以下:

/************************************************************************* 
 > File Name: server.c 
 > Author: SongLee 
 ************************************************************************/ 
#include<sys/types.h> 
#include<sys/socket.h> 
#include<unistd.h> 
#include<netinet/in.h> 
#include<arpa/inet.h> 
#include<stdio.h> 
#include<stdlib.h> 
#include<errno.h> 
#include<netdb.h> 
#include<stdarg.h> 
#include<string.h> 
 
#define SERVER_PORT 8000 
#define BUFFER_SIZE 1024 
#define FILE_NAME_MAX_SIZE 512 
 
int main() 
{ 
 /* 創立UDP套接口 */ 
 struct sockaddr_in server_addr; 
 bzero(&server_addr, sizeof(server_addr)); 
 server_addr.sin_family = AF_INET; 
 server_addr.sin_addr.s_addr = htonl(INADDR_ANY); 
 server_addr.sin_port = htons(SERVER_PORT); 
 
 /* 創立socket */ 
 int server_socket_fd = socket(AF_INET, SOCK_DGRAM, 0); 
 if(server_socket_fd == -1) 
 { 
  perror("Create Socket Failed:"); 
  exit(1); 
 } 
 
 /* 綁定套接口 */ 
 if(-1 == (bind(server_socket_fd,(struct sockaddr*)&server_addr,sizeof(server_addr)))) 
 { 
  perror("Server Bind Failed:"); 
  exit(1); 
 } 
 
 /* 數據傳輸 */ 
 while(1) 
 {  
  /* 界說一個地址,用於捕捉客戶端地址 */ 
  struct sockaddr_in client_addr; 
  socklen_t client_addr_length = sizeof(client_addr); 
 
  /* 吸收數據 */ 
  char buffer[BUFFER_SIZE]; 
  bzero(buffer, BUFFER_SIZE); 
  if(recvfrom(server_socket_fd, buffer, BUFFER_SIZE,0,(struct sockaddr*)&client_addr, &client_addr_length) == -1) 
  { 
   perror("Receive Data Failed:"); 
   exit(1); 
  } 
 
  /* 從buffer中拷貝出file_name */ 
  char file_name[FILE_NAME_MAX_SIZE+1]; 
  bzero(file_name,FILE_NAME_MAX_SIZE+1); 
  strncpy(file_name, buffer, strlen(buffer)>FILE_NAME_MAX_SIZE?FILE_NAME_MAX_SIZE:strlen(buffer)); 
  printf("%s\n", file_name); 
 } 
 close(server_socket_fd); 
 return 0; 
} 

client端代碼以下:

/************************************************************************* 
 > File Name: client.c 
 > Author: SongLee 
 ************************************************************************/ 
#include<sys/types.h> 
#include<sys/socket.h> 
#include<unistd.h> 
#include<netinet/in.h> 
#include<arpa/inet.h> 
#include<stdio.h> 
#include<stdlib.h> 
#include<errno.h> 
#include<netdb.h> 
#include<stdarg.h> 
#include<string.h> 
 
#define SERVER_PORT 8000 
#define BUFFER_SIZE 1024 
#define FILE_NAME_MAX_SIZE 512 
 
int main() 
{ 
 /* 辦事端地址 */ 
 struct sockaddr_in server_addr; 
 bzero(&server_addr, sizeof(server_addr)); 
 server_addr.sin_family = AF_INET; 
 server_addr.sin_addr.s_addr = inet_addr("127.0.0.1"); 
 server_addr.sin_port = htons(SERVER_PORT); 
 
 /* 創立socket */ 
 int client_socket_fd = socket(AF_INET, SOCK_DGRAM, 0); 
 if(client_socket_fd < 0) 
 { 
  perror("Create Socket Failed:"); 
  exit(1); 
 } 
 
 /* 輸出文件名到緩沖區 */ 
 char file_name[FILE_NAME_MAX_SIZE+1]; 
 bzero(file_name, FILE_NAME_MAX_SIZE+1); 
 printf("Please Input File Name On Server:\t"); 
 scanf("%s", file_name); 
 
 char buffer[BUFFER_SIZE]; 
 bzero(buffer, BUFFER_SIZE); 
 strncpy(buffer, file_name, strlen(file_name)>BUFFER_SIZE?BUFFER_SIZE:strlen(file_name)); 
 
 /* 發送文件名 */ 
 if(sendto(client_socket_fd, buffer, BUFFER_SIZE,0,(struct sockaddr*)&server_addr,sizeof(server_addr)) < 0) 
 { 
  perror("Send File Name Failed:"); 
  exit(1); 
 } 
 
 close(client_socket_fd); 
 return 0; 
} 

讀者可以參考比較前一篇:Linux收集編程之socket文件傳輸示例,留意UDP和TCP任務流程的比較。以加深對該法式道理的懂得。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved