国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Linux開發_文件發送與接收

DS小龍哥-嵌入式技術 ? 2022-09-17 15:23 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

【摘要】 介紹文件發送、文件接收、線處理服務器接收、獲取天氣預報等知識點。

任務1:網絡編程

1.1 練習題說明

1.?實現TCP服務器與TCP客戶端之間的基本通信,收發數據 (按照上課的思路流程看函數文檔)

2.?實現TCP服務器與TCP客戶端之間的文件傳輸。(單個文件傳輸)

驗證方式: (1) 同一臺電腦演示 (2)同桌之間演示

考慮的問題:

(1)?網絡的傳輸環境,考慮應答問題

(2)?數據丟包之后如何處理? 可以重發

(3)?超時處理

(4)?服務器與客戶端之間連接斷開處理。(客戶端和服務器兩邊都需要重新連接)

文件傳輸可以在廣告機中使用。

(5)?每個數據的單位: 分包發送

(擴展要求): 顯示接收進度百分比,顯示接收的文件名稱,推薦: 定義結構體(使用數據結構)

3.?(擴展)實現TCP服務器與TCP客戶端之間的目錄傳輸(一級目錄)。

4.?(擴展)實現網絡聊天室(模仿QQ群發送消息的效果)

(1)?加入進去的成員都是客戶端

(2)?服務器負責給各個客戶端轉發消

??一般情況下,推薦最大每次傳輸的字節數不超過1024字節。

(1)文件發送客戶端

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 

/*
TCP客戶端:
1. sockt創建套接字
2. 連接服務器
*/
int socket_cfd; /*保存客戶端套接字*/
int main(int argc,char **argv)
{
	if(argc!=4)
	{
		printf("./server <192.168.xx.xx 服務器的IP地址> <服務器端口號> <文件名稱>\n");
		exit(-1);
	}
	
	FILE *file=fopen(argv[3],"wb");
	if(file==NULL)
	{
		printf("文件創建失敗!");
		exit(0);
	}
	
	int err; //存放返回值狀態
	/*1. 創建套接字*/
	socket_cfd=socket(AF_INET,SOCK_STREAM,0);
	if(socket_cfd<0)
	{
		printf("服務器端創建失敗!\n");
		exit(-1);
	}
	
	/*2.連接服務器*/
	struct sockaddr_in ServerAddr;
	ServerAddr.sin_family=AF_INET; //IPV4協議
	ServerAddr.sin_port=htons(atoi(argv[2]));      //服務器的端口號 最大值65535
	ServerAddr.sin_addr.s_addr=inet_addr(argv[1]); //IP地址賦值
	
	err=connect(socket_cfd,(const struct sockaddr *)&ServerAddr,sizeof(struct sockaddr));
	if(err!=0)
	{
		printf("服務器連接失敗!\n");
		exit(-1);
	}
	
	/*3. 收發數據: 接收服務器發送的數據*/
	char rx_buff[100];
	fd_set readfds; //存放讀事件
	int data;
	int ack=666;
	while(1)
	{
		FD_ZERO(&readfds); //清空文件描述符
		FD_SET(socket_cfd,&readfds); //添加需要監控的文件描述符 
		data=select(socket_cfd+1,&readfds,NULL,NULL,NULL);
		if(data>0)
		{
			err=read(socket_cfd,rx_buff,100);
			if(err==0 && data==1)
			{
				printf("服務器已經與客戶端斷開連接!\n");
				break;
			}
			fwrite(rx_buff,1,err,file);//寫入數據
			printf("客戶端成功接收%d個字節\n",err);
			
			write(socket_cfd,&ack,4); //發送應答信號。
		}
	}
	close(socket_cfd);
	fclose(file);
	return 0;
}

(2)文件發送客戶端

#include 
#include 
#include 
#include 
#include 
#include 

/*
TCP服務器:
1. sockt創建套接字
2. bind綁定端口
3. 設置監聽的數量
4. 等待客戶端連接
*/
int socket_sfd; /*保存了服務器端的套接字*/
int socket_cfd; /*已經連接成功的客戶端套接字*/

/*
服務器是發送端
*/
int main(int argc,char **argv)
{
	if(argc!=4)
	{
		printf("./server <192.168.xx.xx 本地IP地址> <服務器端口號> \n");
		exit(-1);
	}
	
	FILE *file=fopen(argv[3],"rb");
	if(file==NULL)
	{
		printf("文件打開失敗!\n");
		exit(0);
	}
	
	int err; //存放返回值狀態
	/*1. 創建套接字*/
	socket_sfd=socket(AF_INET,SOCK_STREAM,0);
	if(socket_sfd<0)
	{
		printf("服務器端創建失敗!\n");
		exit(-1);
	}
	
	/*2. 綁定端口*/
	struct sockaddr_in ServerAddr;
	ServerAddr.sin_family=AF_INET; //IPV4協議
	ServerAddr.sin_port=htons(atoi(argv[2]));      //服務器的端口號 最大值65535
	ServerAddr.sin_addr.s_addr=inet_addr(argv[1]); //IP地址賦值
	err=bind(socket_sfd,(const struct sockaddr *)&ServerAddr,sizeof(struct sockaddr));
	if(err!=0)
	{
		printf("服務器端 端口綁定失敗!\n");
		exit(-1);
	}
	
	/*3. 設置監聽的數量*/
	listen(socket_sfd,10);
	
	/*4. 等待客戶端連接*/
	struct sockaddr_in ClientAddr; //存放已經連接成功客戶端信息
	socklen_t addrlen=sizeof(struct sockaddr);    //客戶端的地址長度
	socket_cfd=accept(socket_sfd,(struct sockaddr *)&ClientAddr,&addrlen);
	if(socket_cfd<0)
	{
		printf("服務器端,連接客戶端失敗!\r\n");
		exit(-1);
	}
	
	/*打印一些客戶端的信息*/
	printf("成功連接的客戶端端口號:%d\n",ntohs(ClientAddr.sin_port));
	printf("成功連接的客戶端IP地址:%s\n",inet_ntoa(ClientAddr.sin_addr));
	
	/*5. 收發數據 :服務器給客戶端發送10個字節的數據*/
	char tx_buff[100];
	int len;
	int ack;
	while(1)
	{
		len=fread(tx_buff,1,100,file);
		printf("服務器成功發送:%d 字節\r\n",len);
		err=write(socket_cfd,tx_buff,len);
		while(1)
		{
			err=read(socket_cfd,&ack,4);  //等待客戶端的應答
			if(err>0&&ack==666)
			{
				break;
			}
		}	
		if(len!=100)break;
	}
	close(socket_sfd);
	fclose(file);
	return 0;
}

文件名稱>

任務2:線程編程

#include

int pthread_create(pthread_t *thread, const pthread_attr_t *attr,

void *(*start_routine) (void *), void *arg);

Compile and link with -pthread.

-lpthread

理解: 一個線程就是一個while(1)。

[root@wbyq linux-share-dir]# gcc app.c

/tmp/cccOs4TK.o: In function `main':

app.c:(.text+0x69): undefined reference to `pthread_create'

app.c:(.text+0x8d): undefined reference to `pthread_create'

collect2: ld 返回 1

[root@wbyq linux-share-dir]# gcc app.c -lpthread

練習:

1.?學習線程的基本使用

2.?實現一個服務器實現多個客戶端的連接,實現通信。

思路: 一個客戶端就是一個獨立的線程。

3.?擴展練習: 實現服務器同時對多個客戶端進行文件發送。

(1)?服務器連接上一個客戶端就創建一個線程。

(2)?線程的函數需要寫幾個? 1個

1個函數需要考慮的問題: 函數的可重入性能!

需要考慮到資源搶占! 使用信號量!

1.?CRC16、CRC32校驗、

2.?和校驗 ”abcd <校驗和>” -->和

3.?異或校驗。 (1) 文件加密解碼

(2) 不添加三個變量,將兩個變量的值交換

int a=666; int b=888;

4.?MD5值校驗。

客戶端:

#include 
#include           /* See NOTES */
#include 
#include    //使用大小端轉換函數. find /
#include 
/*服務器端口號定義*/
#define P_host 8080

//  ./app   192.168.18.3
/*TCP客戶端代碼*/
int main(int argc,char *argv[])
{
	  if(argc!=2)
	  {
	  	  printf("參數錯誤:./app <服務器IP地址>\n");
	  		return -1;
	  }
	 int clientfd;
	 struct sockaddr_in server_address;     //存放服務器的IP地址信息
	 memset(&server_address,0,sizeof(struct sockaddr_in)); //初始化內存空間
	 server_address.sin_family=AF_INET;            //IPV4協議
	 server_address.sin_port=htons(P_host);        //端口號賦值
	 server_address.sin_addr.s_addr=inet_addr(argv[1]);    //本地IP地址
	 /*1 .創建套接字*/
    clientfd=socket(AF_INET,SOCK_STREAM,0);
   if(clientfd<0)
   	{
   	    printf("客戶端網絡套接字創建失敗!\n");	
   	    return -1;
   	}
   	
   	/*2. 連接服務器*/
   	if(connect(clientfd,(const struct sockaddr *)&server_address,sizeof(struct sockaddr))!=0)
   	{
   		  printf("客戶端連接服務器失敗!\n");	
   	    return -1; 	
   	}
   	char buff[1024];
   	
   	while(1)
   	{
   	    gets(buff);
   	    write(clientfd,buff,strlen(buff)); 
   	}
		return 0;
}

服務器:

#include 
#include           /* See NOTES */
#include 
#include    //使用大小端轉換函數
#include 
#include 
#include 
#include 
#include 
#include 
//函數聲明
void *start_routine_1(void *dev);
void *start_routine_2(void *dev);

typedef void *(*start_routine) (void *);
start_routine fun[]={start_routine_1,start_routine_2};
pthread_t thread_id[2];                //存放線程的標識符
int clientfd[2];                       //保存TCP客戶端的網絡套接字
struct sockaddr_in client_address[2];  //存放客戶端的信息
socklen_t address_len[2];              //存放客戶端結構體信息的長度
/*服務器端口號定義*/
#define P_host 8080

/*TCP服務器代碼*/
int main(int argc,char *argv[])
{
	 int socketfd;
	 struct sockaddr_in server_address;     //存放服務器的IP地址信息
	 memset(&server_address,0,sizeof(struct sockaddr_in)); //初始化內存空間
	 memset(client_address,0,sizeof(struct sockaddr_in)*2); //初始化內存空間
	 server_address.sin_family=PF_INET;            //IPV4協議
	 server_address.sin_port=htons(P_host);        //端口號賦值
	 server_address.sin_addr.s_addr=INADDR_ANY;    //本地IP地址
  /*1 .創建套接字*/
   socketfd=socket(PF_INET,SOCK_STREAM,0);
   if(socketfd<0)
   	{
   	    printf("服務器網絡套接字創建失敗!\n");	
   	    return -1;
   	}
      	 
   /*2. 綁定端口,創建服務器*/
   if(bind(socketfd,(const struct sockaddr *)&server_address,sizeof(struct sockaddr))!=0)
   	{
   	    printf("服務器綁定端口失敗!\n");	
   	    return -1; 	
   	}
   
   /*3. 設監聽的端口數量*/
   if(listen(socketfd,10)!=0)
   	{
   	   printf("服務器端口監聽失敗!\n");	
   	   return -1;	 
   	}
   
    int i;
    
    for(i=0;i<2;i++)
   	{
   		 address_len[i]=sizeof(struct sockaddr);  //計算結構體大小 20 
   	  /*4. 等待客戶端連接*/
	    if((clientfd[i]=accept(socketfd,(struct sockaddr *)&client_address[i],&address_len[i]))<0)
	   	{
	   	   	printf("等待客戶端連接失敗!\n");	
	   	    break;	
	   	} 
	    
	    //創建線程
	   	if(pthread_create(&thread_id[i],NULL,fun[i],NULL)!=0)
		{
		   printf("線程_%d_創建失敗!\n",i);		
		} 	
   	}
   	
   	while(1)
   	{
   	    	
   	}
     	
   //阻塞方式等待線程的結束
	pthread_join(thread_id[0],NULL);
	pthread_join(thread_id[1],NULL);
	return 0;	
}
//線程1
void *start_routine_1(void *dev)
{
	 while(1)
	 {
	 	  printf("TCP客戶端1連接!\n");
	 	  sleep(2);
	 }
	 //終止線程
	 pthread_exit(NULL);
}
//線程2
void *start_routine_2(void *dev)
{
	while(1)
	{
	 	  printf("TCP客戶端2連接!\n");
	 	  sleep(2);
	}
	 //終止線程
	 pthread_exit(NULL);
}

任務3:使用的網絡服務器接口

C語言:面向過程 、 面向對象

1.?車牌號識別

2.?二維碼生成

3.?獲取北京時間

獲取接口的網址:http://www.k780.com/

1.?調用網絡的接口的方式: (天氣預報)

curl http://api.k780.com:88/?app=weather.future'&'weaid=南昌

'&&'appkey=10003'&'sign=b59bc3ef6191eb9f747dd4e83c99f2a4'&'format=json >123.txt

注意: &是特殊的符號,需要使用單引號或者雙引號括起來。

Curl: 命令行的瀏覽器。

2.?調用二維碼生成的接口

curl http://api.k780.com:88/?app=qr.get'&'data=www.wanbangee.com'&'level=L'&'size=6 >123.png

?? 練習:

1.?天氣預報查詢

查詢的格式: ./app <城市的中文名稱>

poYBAGMlPamARKUnAAA4mjEWJsA386.png

2.?獲取北京標準時間,顯示出來

pYYBAGMlPamAcAvwAAAMsIAQj18578.png

3.?二維碼生成創建 運行格式: ./app <生成的二維碼內容>

生成之后直接顯示在屏幕上。可以使用eog命令

4.?車牌號的識別

5.?調用百度地圖API接口 http://lbsyun.baidu.com/index.php?title=uri/api/web

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 服務器
    +關注

    關注

    14

    文章

    10253

    瀏覽量

    91490
  • TCP
    TCP
    +關注

    關注

    8

    文章

    1425

    瀏覽量

    83516
  • 文件
    +關注

    關注

    1

    文章

    594

    瀏覽量

    26061
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    Linux文件刪除的底層原理和恢復方法

    rm -rf 大概是 Linux 世界里殺傷力最大的命令,沒有之一。手一抖、路徑一錯、通配符一飄,幾個 G 的數據就沒了。更要命的是 Linux 默認沒有回收站機制,rm 刪掉的文件不會像 Windows 那樣安靜地躺在回收站里
    的頭像 發表于 02-11 09:14 ?465次閱讀

    深入RK3588內核:rockchip_linux_defconfig的作用與調試價值

    在 RK3588 芯片的 Linux 開發中,有一個文件始終是開發者繞不開的核心 ——kernel/arch/arm64/configs/rockchip_
    的頭像 發表于 02-03 15:56 ?1163次閱讀
    深入RK3588內核:rockchip_<b class='flag-5'>linux</b>_defconfig的作用與調試價值

    Linux開發嵌入式必備命令速查表

    在嵌入式開發中,Linux系統幾乎成為必備的開發環境。不管你是在做STM32、RaspberryPi、還是基于ARM的板子,熟練掌握Linux命令不僅能加快
    的頭像 發表于 01-19 09:06 ?884次閱讀
    <b class='flag-5'>Linux</b> 下<b class='flag-5'>開發</b>嵌入式必備命令速查表

    【免費送書】成為硬核Linux開發者:《Linux 設備驅動開發(第 2 版)》

    Linux系統的設備驅動開發,一直給人門檻較高的印象,主要因內核機制抽象、需深度理解硬件原理、開發調試難度大所致。2021年,一本講解驅動開發的專著問世即獲市場青睞,暢銷近萬冊——這便
    的頭像 發表于 11-18 08:06 ?1414次閱讀
    【免費送書】成為硬核<b class='flag-5'>Linux</b><b class='flag-5'>開發</b>者:《<b class='flag-5'>Linux</b> 設備驅動<b class='flag-5'>開發</b>(第 2 版)》

    Linux新手通關!5分鐘掌握文件/目錄管理,告別“找不到北”

    新手入門:Linux?文件?/?目錄管理實操指南 剛上手?Linux?的小伙伴,是不是常陷入這些?“混亂時刻”:想找的文件藏在層層目錄里,翻半天找不到;誤刪
    的頭像 發表于 11-17 10:42 ?429次閱讀
    <b class='flag-5'>Linux</b>新手通關!5分鐘掌握<b class='flag-5'>文件</b>/目錄管理,告別“找不到北”

    接收Ymedom文件后釋放內存報錯,重啟怎么解決?

    測試OTA功能正常了,使用sy發送文件也是正常,使用ry接收數據后提示釋放內存出錯系統重啟了。這里困擾住了,文件已經正常存放在根文件系統下
    發表于 09-28 09:07

    RK3506開發Linux開發板極致性價比之選

    RK3506開發Linux開發板極致性價比之選瑞芯微RK3506開發板,3核Cortex-A7@1.5GHz+Cortex-M0,Linux
    的頭像 發表于 09-11 16:26 ?3466次閱讀
    RK3506<b class='flag-5'>開發</b>板<b class='flag-5'>Linux</b><b class='flag-5'>開發</b>板極致性價比之選

    Linux 應用開發手冊

    T507linux應用開發手冊
    發表于 08-22 17:01 ?15次下載

    Linux三大主流文件系統解析

    還在為選擇哪個文件系統而糾結?作為一名摸爬滾打多年的運維老鳥,我將用最接地氣的方式,帶你徹底搞懂 Linux 三大主流文件系統的奧秘。
    的頭像 發表于 08-05 17:37 ?1447次閱讀

    2.4GHZ 發送/接收 ZIGBEE RFEIC,帶分集開關 skyworksinc

    電子發燒友網為你提供()2.4GHZ 發送/接收 ZIGBEE RFEIC,帶分集開關相關產品參數、數據手冊,更有2.4GHZ 發送/接收 ZIGBEE RFEIC,帶分集開關的引腳圖
    發表于 06-26 18:35
    2.4GHZ <b class='flag-5'>發送</b>/<b class='flag-5'>接收</b> ZIGBEE RFEIC,帶分集開關 skyworksinc

    Linux修改uboot啟動延時方法詳細攻略,觸覺智能RK3568開發板演示

    OpenHarmony3.2-5.0,以及Linux、Android等操作系統,接口豐富,開發評估快人一步!修改uboot延時首先查找defconfig文件./build.shub
    的頭像 發表于 06-06 18:07 ?943次閱讀
    <b class='flag-5'>Linux</b>修改uboot啟動延時方法詳細攻略,觸覺智能RK3568<b class='flag-5'>開發</b>板演示

    Linux文件系統打包及鏡像制作,觸覺智能RK3562開發板演示

    本文介紹Linux開發文件系統打包及鏡像制作的方法,演示Linux文件系統打包及鏡像制作,適用于想將配置好的系統環境打包成鏡像批量燒錄。觸
    的頭像 發表于 04-28 16:45 ?1002次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>文件</b>系統打包及鏡像制作,觸覺智能RK3562<b class='flag-5'>開發</b>板演示

    【道生物聯TKB-620開發板試用】燒錄示例工程

    OLED顯示屏上顯示發送與接收的信息如下: 【小結】 通過燒錄固件,驗證開發板的demo,下面就可以進入實際開發了。 【建議】 在工程中最好加入一個readme.txt
    發表于 04-17 13:44

    [迅為]Linux開發小技巧:Remote - SSH插件

    [迅為]Linux開發小技巧:Remote - SSH插件
    的頭像 發表于 04-01 15:46 ?1168次閱讀
    [迅為]<b class='flag-5'>Linux</b><b class='flag-5'>開發</b>小技巧:Remote - SSH插件

    從零開始馴服Linux(一):ZYNQ-Linux啟動文件構建全解析

    定位問題并優化代碼。本教程我們就一起來看一下,如何基于正點原子提供的出廠相關源代碼,制作ZYNQ開發板的啟動文件,并成功運行Linux系統。 1.1制作前準備工作1)、一款ZYNQ開發
    發表于 03-20 16:48