C語言實現(xiàn)Linux下的socket文件傳輸實例
更新時間:2015年06月29日 09:59:30 作者:紅薯
這篇文章主要介紹了C語言實現(xiàn)Linux下的socket文件傳輸的方法,較為詳細的分析了C語言文件Socket文件傳輸客戶端與服務器端相關實現(xiàn)技巧,需要的朋友可以參考下
本文實例講述了C語言實現(xiàn)Linux下的socket文件傳輸。分享給大家供大家參考。具體如下:
server.c如下:
//////////////////////////////////// //服務器代碼 /////////////////////////////////// //本文件是服務器的代碼 #include <netinet/in.h> // for sockaddr_in #include <sys/types.h> // for socket #include <sys/socket.h> // for socket #include <stdio.h> // for printf #include <stdlib.h> // for exit #include <string.h> // for bzero #include <time.h> //for time_t and time #define HELLO_WORLD_SERVER_PORT 7754 #define LENGTH_OF_LISTEN_QUEUE 20 #define BUFFER_SIZE 1024 int main(int argc, char **argv) { //設置一個socket地址結構server_addr,代表服務器internet地址, 端口 struct sockaddr_in server_addr; bzero(&server_addr,sizeof(server_addr)); //把一段內存區(qū)的內容全部設置為0 server_addr.sin_family = AF_INET; server_addr.sin_addr.s_addr = htons(INADDR_ANY); server_addr.sin_port = htons(HELLO_WORLD_SERVER_PORT); // time_t now; FILE *stream; //創(chuàng)建用于internet的流協(xié)議(TCP)socket,用server_socket代表服務器socket int server_socket = socket(AF_INET,SOCK_STREAM,0); if( server_socket < 0) { printf("Create Socket Failed!"); exit(1); } //把socket和socket地址結構聯(lián)系起來 if( bind(server_socket,(struct sockaddr*)&server_addr,sizeof(server_addr))) { printf("Server Bind Port : %d Failed!", HELLO_WORLD_SERVER_PORT); exit(1); } //server_socket用于監(jiān)聽 if ( listen(server_socket, LENGTH_OF_LISTEN_QUEUE) ) { printf("Server Listen Failed!"); exit(1); } while (1) //服務器端要一直運行 { struct sockaddr_in client_addr; socklen_t length = sizeof(client_addr); int new_server_socket = accept(server_socket,(struct sockaddr*)&client_addr,&length); if ( new_server_socket < 0) { printf("Server Accept Failed!\n"); break; } char buffer[BUFFER_SIZE]; bzero(buffer, BUFFER_SIZE); strcpy(buffer,"Hello,World! 從服務器來!"); strcat(buffer,"\n"); //C語言字符串連接 send(new_server_socket,buffer,BUFFER_SIZE,0); bzero(buffer,BUFFER_SIZE); //接收客戶端發(fā)送來的信息到buffer中 length = recv(new_server_socket,buffer,BUFFER_SIZE,0); if (length < 0) { printf("Server Recieve Data Failed!\n"); exit(1); } printf("\n%s",buffer); if((stream = fopen("data1","r"))==NULL) { printf("The file 'data1' was not opened! \n"); exit(1); } else printf("The file 'filename' was opened! \n"); bzero(buffer,BUFFER_SIZE); int lengsize = 0; while((lengsize = fread(buffer,1,1024,stream)) > 0) { printf("lengsize = %d\n",lengsize); if(send(new_server_socket,buffer,lengsize,0)<0) { printf("Send File is Failed\n"); break; } bzero(buffer, BUFFER_SIZE); } if(fclose(stream)) printf("The file 'data' was not closed! \n"); exit(1); //關閉與客戶端的連接 close(new_server_socket); } //關閉監(jiān)聽用的socket close(server_socket); return 0; }
client.c如下:
//////////////////////////////////// //客戶端代碼 /////////////////////////////////// //本文件是客戶機的代碼 #include <netinet/in.h> // for sockaddr_in #include <sys/types.h> // for socket #include <sys/socket.h> // for socket #include <stdio.h> // for printf #include <stdlib.h> // for exit #include <string.h> // for bzero #include <time.h> //for time_t and time #include <arpa/inet.h> #define HELLO_WORLD_SERVER_PORT 7754 #define BUFFER_SIZE 1024 int main(int argc, char **argv) { if (argc != 2) { printf("Usage: ./%s ServerIPAddress\n",argv[0]); exit(1); } //time_t now; FILE *stream; //設置一個socket地址結構client_addr,代表客戶機internet地址, 端口 struct sockaddr_in client_addr; bzero(&client_addr,sizeof(client_addr)); //把一段內存區(qū)的內容全部設置為0 client_addr.sin_family = AF_INET; //internet協(xié)議族 client_addr.sin_addr.s_addr = htons(INADDR_ANY);//INADDR_ANY表示自動獲取本機地址 client_addr.sin_port = htons(0); //0表示讓系統(tǒng)自動分配一個空閑端口 //創(chuàng)建用于internet的流協(xié)議(TCP)socket,用client_socket代表客戶機socket int client_socket = socket(AF_INET,SOCK_STREAM,0); if( client_socket < 0) { printf("Create Socket Failed!\n"); exit(1); } //把客戶機的socket和客戶機的socket地址結構聯(lián)系起來 if( bind(client_socket,(struct sockaddr*)&client_addr,sizeof(client_addr))) { printf("Client Bind Port Failed!\n"); exit(1); } //設置一個socket地址結構server_addr,代表服務器的internet地址, 端口 struct sockaddr_in server_addr; bzero(&server_addr,sizeof(server_addr)); server_addr.sin_family = AF_INET; if(inet_aton(argv[1],&server_addr.sin_addr) == 0) //服務器的IP地址來自程序的參數 { printf("Server IP Address Error!\n"); exit(1); } server_addr.sin_port = htons(HELLO_WORLD_SERVER_PORT); socklen_t server_addr_length = sizeof(server_addr); //向服務器發(fā)起連接,連接成功后client_socket代表了客戶機和服務器的一個socket連接 if(connect(client_socket,(struct sockaddr*)&server_addr, server_addr_length) < 0) { printf("Can Not Connect To %s!\n",argv[1]); exit(1); } char buffer[BUFFER_SIZE]; bzero(buffer,BUFFER_SIZE); //從服務器接收數據到buffer中 int length = recv(client_socket,buffer,BUFFER_SIZE,0); if(length < 0) { printf("Recieve Data From Server %s Failed!\n", argv[1]); exit(1); } printf("\n%s\n",buffer); bzero(buffer,BUFFER_SIZE); bzero(buffer,BUFFER_SIZE); strcpy(buffer,"Hello, World! From Client\n"); //向服務器發(fā)送buffer中的數據 send(client_socket,buffer,BUFFER_SIZE,0); if((stream = fopen("data","w+t"))==NULL) { printf("The file 'data' was not opened! \n"); } else bzero(buffer,BUFFER_SIZE); length = 0; while( length = recv(client_socket,buffer,BUFFER_SIZE,0)) { if(length < 0) { printf("Recieve Data From Server %s Failed!\n", argv[1]); break; } int write_length = fwrite(buffer,sizeof(char),length,stream); if (write_length<length) { printf("File is Write Failed\n"); break; } bzero(buffer,BUFFER_SIZE); } printf("Recieve File From Server[%s] Finished\n", argv[1]); //關閉 文件 fclose(stream); //關閉socket close(client_socket); return 0; }
希望本文所述對大家的C語言程序設計有所幫助。
相關文章
淺談stringstream 的.str()正確用法和清空操作
下面小編就為大家?guī)硪黄獪\談stringstream 的.str()正確用法和清空操作。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12C++編程之CString、string與、char數組的轉換
這篇文章主要介紹了C++編程之CString、string與、char數組的轉換的相關資料,希望通過本文能幫助到大家,讓大家學習理解這部分內容,需要的朋友可以參考下2017-10-10C語言的sleep、usleep、nanosleep等休眠函數的使用
本文主要介紹了C語言的sleep、usleep、nanosleep等休眠函數的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-03-03C/C++通過SQLite SDK實現(xiàn)數據庫增刪改查操作
SQLite,作為一款嵌入式關系型數據庫管理系統(tǒng),一直以其輕量級、零配置以及跨平臺等特性而備受青睞,本文主要介紹了C++如何通過SQLite SDK實現(xiàn)數據庫增刪改查操作,感興趣的可以了解下2023-11-11