标签:检测 eve 服务器 too 对话框 height crc 避免 技术
<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文件里面的版本号做对比
这种方式完全避免了上面说的那种问题!
后期的教程之所以改了方案,是因为要兼容各大物联网平台!
有些平台只提供了上传固件到服务器的功能,然后上传的时候设置一下版本号
然后如果单片机想升级,就上报一下自己程序的版本号,云平台去判断版本如果不一致
就把程序或程序下载链接发给单片机.最后单片机去下载,下载完成以后上报一下最新的版本号.
用户会发现,物联网平台并没有提供获取云端版本号的接口.
如果不把固件版本写到用户程序里面,那么就接入不了某些物联网平台了!
当时我考虑由于操作人员疏忽而造成反复升级的比重太小.
一次编写到处运行占的比重更大!
所以我才定的这个方案.
当然有些用户确实担心这个问题,所以我预期提供下面解决的方式
{"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 字段的值弄几个对话框,让用户填写.
这样子即提高了效率也降低了失误的可能.
STM32+ESP8266+AIR202/302远程升级方案-程序优化3-关于版本号判断的问题
标签:检测 eve 服务器 too 对话框 height crc 避免 技术
原文地址:https://www.cnblogs.com/yangfengwu/p/13977561.html