在鸿蒙设备上运行TFTP服务器,实现文件上传、下载、保存
昨天唐老师发布了能够运行在鸿蒙Hi3861开发板上的Python解释器,还不知道的可以去看看唐老师的帖子,😃
我们知道,Python是一种脚本语言,可以解释执行,不需要编译。有了Python解释器,大家可能会希望——如果能直接把Python脚本文件上传到开发板上,然后发个命令就可以执行就好了,而不需要像C代码那样需要编译、烧录 才能运行。
于是,我开始尝试——将TFTP服务器移植到鸿蒙Hi3861开发板上。经过半天的移植和一天的调试,终于把TFTP服务器在Hi3861上移植成功了。
没错,在内存352KB、闪存2M 的Hi3861开发板上成功运行了一个TFTP服务器,你可以将PC上的文件上传到开发板上,而且可以断电持久保存!当然,你上传的文件不能太大。
以下是整个移植和调试过程中的关键过程记录。
TFTP是什么?
TFTP是简单文件传输协议 Trivial File Transfer Protocol的英文缩写。
TFTP是基于UDP的,协议本身比较简单,它的RFC 1350官方文档也只有11页(TCP的RFC 793文档有85页)。
如果大家如果有兴趣,完全可以自己从零实现一个;而我为了能够快速验证在Hi3861的可行性,选择了直接移植。
TFTP服务器实现了哪些功能?
已经实现了TFTP该有的功能:
-
支持文件上传;
-
支持文件下载;
-
支持文件持久保存,使用了鸿蒙的文件系统API接口;
运行效果
PC通过网线连接无线路由器,虚拟机网口桥接网卡,IP地址:192.168.1.157;
开发板连接通过WiFi连接到无线路由器,IP地址:192.168.1.151 ;
下图是运行效果,左边为虚拟机上 shell 执行的命令;
其中的用到的几个命令格式为:
-
put命令,将本地文件上传到服务器,格式:put localfile remotefile
-
get命令,将服务器上的文件下载到本地,格式:get remotename localname
-
quit命令,退出会话
想尝试运行效果的,可以直接下载本帖附件的代码进行编译,运行。
如何编译
-
将本帖附件tftp代码解压到openharmony源码顶层目录;
-
修改openharmony的build/lite/product/wifiiot.json文件:
将其中的//applications/sample/wifi-iot/app替换为//tftp:tftp;
-
在openharmony源码的顶层目录,执行python build.py wifiiot;
调试过程中用到的工具和方法
除了常规的串口工具之外,还用到了几个工具(移植其他网络协议时可供参考):
-
tftp 客户端命令行工具(sudo apt install tftp下载);
-
tcpdump 抓包工具;
抓取某个网口上的全部数据包:sudo tcpdump -i eth0 -w tftp.pcap (-i 指定网口,-w 指定保存的数据文件)
- WireShark 抓包和分析工具;
tcpdump抓到的数据包是这个网口上的全部数据,用WireShark分析时,可以用过滤表达式:tftp 过滤TFTP协议的数据包;
解决的问题
移植过程中解决了这么几个问题:
-
解决了报错"Mode too long/not NULL terminated",导致的上传失败;
-
解决了文件读取时size超过了文件实际尺寸的问题;
-
解决了DATA响应数据为空,导致的下载失败的问题;
附件说明
-
tftp.zip 是本移植项目源码;
-
rfc1350.pdf 是TFTP协议参考文档;
作者:许思维
想了解更多内容,请访问: 51CTO和华为官方战略合作共建的鸿蒙技术社区https://harmonyos.51cto.com