STM32+ESP8266+AIR202/302远程升级方案-程序优化3-关于版本号判断的问题

<p><iframe name="ifd" src="https://mnifdv.cn/resource/cnblogs/ESA2GJK1DH1K_B/" frameborder="0" scrolling="auto" width="100%" height="1500"></iframe></p>

说明

 当前的程序,版本号是用一个数组记录在了用户程序里面

每次升级固件的时候,需要修改这个版本号,然后info.txt文件里面的版本号也需要跟着修改

用户程序运行的时候,获取info.txt文件里面的版本号.

然后和自己程序里面的   char FirmwareVersion[FirmwareVersionLen] = "0.0.2";

进行对比,如果不一致就说明有新版本.

问题

如果开发人员疏忽,本身用户程序里面写的是 0.0.2

但是info.txt里面写的是0.0.3

就是说,没有对应起来,就会出现问题!

用户程序里面是0.0.2,而从info.txt一直得到的是0.0.3所以就会检测出来一直有新版本,

导致一直在升级程序.

为什么要把版本号写到用户程序里面

如果用户看过我老版本的教程,会发现并没有把版本写在用户程序里面

而是每次升级完成的时候把info.txt文件里面的版本号保存到Flash记录下来.

检测升级的时候是拿着本地记录的版本号和云端的info.txt文件里面的版本号做对比

这种方式完全避免了上面说的那种问题!

后期的教程之所以改了方案,是因为要兼容各大物联网平台!

有些平台只提供了上传固件到服务器的功能,然后上传的时候设置一下版本号

然后如果单片机想升级,就上报一下自己程序的版本号,云平台去判断版本如果不一致

就把程序或程序下载链接发给单片机.最后单片机去下载,下载完成以后上报一下最新的版本号.

用户会发现,物联网平台并没有提供获取云端版本号的接口.

如果不把固件版本写到用户程序里面,那么就接入不了某些物联网平台了!

当时我考虑由于操作人员疏忽而造成反复升级的比重太小.

一次编写到处运行占的比重更大!

所以我才定的这个方案.

当然有些用户确实担心这个问题,所以我预期提供下面解决的方式

方式1:由OTA Tools软件生成info.txt文件

{"version":"0.0.3","size":16120,"url":"http://mnif.cn/ota/hardware/STM32ESP8266BK/user_crc.bin","info":"1.解决了部分BUG
2.优化了部分程序"}

现在主要解决的是info.txt里面的版本号和程序文件里面版本号容易修改错的问题.

那就不让用户去修改.直接用软件生成info.txt

version ,size 和 url 的字段的值都由软件提取bin文件信息生成.

最后 info 字段的值弄几个对话框,让用户填写.

这样子即提高了效率也降低了失误的可能.

原文地址:https://www.cnblogs.com/yangfengwu/p/13977561.html