HaaS100 OTA之固件验签功能介绍

简介: 本文主要介绍HaaS100 对升级的固件做验签的功能进而防止升级非法固件;

1、概述

本文主要介绍HaaS100 对升级的固件做验签的功能进而防止升级非法固件;如下图流程所示,当用户开启阿里云IOT物联网平台的安全升级功能,对应的产品就启动了针对这个产品的安全升级功能,云端会对这个产品的升级固件做秘钥、公钥管理并对这个产品的固件做数字签名;对应的设备端,在OTA的过程中,会用从云端获取的公钥对升级的固件做数字签名的验证;整个流程,用户不需要管理公私钥,使用起来也非常方便,下图为HaaS100 安全升级使用流程图:

image.png

2、使用流程

2.1、开发环境搭建

组件使用示例相关的代码下载、编译和固件烧录均依赖AliOS Things配套的开发工具 alios-studio ,所以首先需要参考《aos-studio使用说明之搭建开发环境》,下载安装 alios-studio ,待开发环境搭建完成后,可以按照以下步骤进行示例的测试。

2.2、 创建工程

创建新的工程:
组件的示例代码可以通过编译链接到AliOS Things的任意案例(solution)来运行,这里选择ota_demo案例, 开发板:HaaS100。

ota_demo案例相关的源代码下载可参考《aos-studio使用说明之创建工程》

打开已有工程:
如果用于测试的案例工程已存在,可参考《aos-studio使用说明之打开工程》打开已有工程。

2.3、打开云端安全升级功能并获取公钥

image.png

2.4、将公钥内嵌到代码中

如步骤1图示,通过复制按钮获取的公钥内嵌到 AliOS-Things/components/dm/ota/hal/ota_hal_digest.c文件中,覆盖如下的两个数组:

/* RSA Public Key:User needs sign in alibaba cloud to get and replace them. */
 
static const unsigned char ota_pubn_buf[256];
 
static const unsigned char ota_pube_buf[3];

2.5、配置固件版本号

根据需求修改版本号,如app-1.0.0等
修改位置:solutions/ota_demo/otaappdemo.c中的,MY_APP_VER宏定义。

2.6、配置四元祖

修改位置:solutions/ota_demo/otaappdemo.c中的,mqtt_main函数中的char product_key, char device_name, char *device_secret;填入自己的pk,dn,ds;

2.7、编译固件

完成上面步骤后,就可以编译ota_demo案例来生成固件了,具体编译方法可参考《aos-studio使用说明之编译固件》

2.8、烧录固件

ota_demo案例的固件生成后,可参考《aos-studio使用说明之烧录固件》来烧录固件。

2.9、打开串口

固件烧录完成后,可以通过串口查看示例的运行结果,打开串口的具体方法可参考《aos-studio使用说明之查看日志》
当串口终端打开成功后,可在串口中输入help来查看已添加的测试命令。

2.10、配网连云

输入wifi账号和密码配网:在终端输入:
netmgr -t wifi -c wifi_ssid wifi_password
注意修改其中的wifi_ssid和wifi_password为需要连接的wifi名字和wifi密码。
连网成功后,登录物联网平台可以看到对应的设备在线:

image.png

2.11、编译上云固件及云端操作

本地烧录完成后,需要做一个高版本固件上传到云端,通过云端操作完成固件的升级,所以需要按照步骤3中修改版本号的方法,修改固件版本号,其他不用修改,再编译生成一个高版本的固件,然后登录物联网平台平台,按如下图顺序操作:

image.png

点击添加固件后,如下图将platform/mcu/haas1000/release/write_flash_gui/ota_bin/ota_bin/ota_rtos_ota.bin上传到云端:

image.png

点击确定后,选择验证固件即可开始固件升级;

2.12、升级结果验证

按照上面的操作步骤完成后,可以完成固件的数字签名验签进而实现固件升级,端侧的log如下图:

image.png

如果开启了安全升级,但HaaS100没有内嵌公钥,触发升级会怎么样呢?答案是HaaS100会数字签名验证失败,禁止固件升级,端侧的log会如下图所示:

image.png

云端升级结果可以通过点击“查看”获取详情;物联网平台的OTA操作可参考文档阿里云物联网平台固件升级文档

注:在做OTA之前确保设备端已连接云端

开发者支持

HaaS解决方案中心:https://haas.iot.aliyun.com/
HaaS技术社区:https://blog.csdn.net/HaaSTech

开发者钉钉群和公众号见下图,开发者钉钉群每天都有技术支持同学值班。

image.png

相关实践学习
钉钉群中如何接收IoT温控器数据告警通知
本实验主要介绍如何将温控器设备以MQTT协议接入IoT物联网平台,通过云产品流转到函数计算FC,调用钉钉群机器人API,实时推送温湿度消息到钉钉群。
阿里云AIoT物联网开发实战
本课程将由物联网专家带你熟悉阿里云AIoT物联网领域全套云产品,7天轻松搭建基于Arduino的端到端物联网场景应用。 开始学习前,请先开通下方两个云产品,让学习更流畅: IoT物联网平台:https://iot.console.aliyun.com/ LinkWAN物联网络管理平台:https://linkwan.console.aliyun.com/service-open
相关文章
|
存储 运维 监控
阿里云物联网平台高级功能之固件升级
OTA(Over-the-Air Technology)即空中下载技术。阿里云物联网平台支持通过OTA方式进行设备固件升级。本文以MQTT协议下的固件升级为例,介绍OTA固件升级流程、数据流转使用的Topic和数据格式。本文使用MQTT.fx客户端模拟设备,进行固件升级流程的操作演示。
2698 0
阿里云物联网平台高级功能之固件升级
|
网络协议 开发工具 数据安全/隐私保护
ESP8266固件SDK开发之微信配网(AIRKISS)原理(一)
ESP8266固件SDK开发之微信配网(AIRKISS)原理(一)
357 0
|
运维 监控 Java
通过云端API完成OTA升级包上传
通过云端API完成OTA升级包上传
通过云端API完成OTA升级包上传
|
API 开发工具 对象存储
物联网平台使用云端API上传OTA升级包
云端API使用,使用API上传OTA升级包最佳实践
662 15
物联网平台使用云端API上传OTA升级包
|
供应链 安全 物联网
IoT 固件安全检测(FSS)最佳实践|学习笔记
快速学习 IoT 固件安全检测(FSS)最佳实践
681 0
IoT 固件安全检测(FSS)最佳实践|学习笔记
HH
|
物联网 API 开发工具
物联网平台之python语言的设备端接入、云端sdk集成调用
本文介绍如何调用Python语言的Paho MQTT类库,将设备接入阿里云物联网平台,并进行消息收发。 以及物联网平台提供Python语言的云端SDK供开发人员使用。本文介绍云端Python SDK的安装和配置,及使用Python SDK调用云端API的示例。
HH
864 0
物联网平台之python语言的设备端接入、云端sdk集成调用
|
运维 物联网 数据格式
IoT物联网设备「固件升级」OTA,「资源包更新」最佳实践
IoT物联网设备「固件升级」OTA,「资源包更新」最佳实践
1978 0
|
物联网
阿里云物联网平台OTA升级设备端主动申请升级固件测试
完整云端OTA升级可以参考文章 https://developer.aliyun.com/article/717007 本文测试设备主动拉取升级固件的topic 请求Topic:/sys/{productKey}/{deviceName}/thing/ota/firmware/get 响应Topic:/sys/{productKey}/{deviceName}/thing/ota/firmware/get_reply
1585 0
阿里云物联网平台OTA升级设备端主动申请升级固件测试
|
前端开发 开发工具 Windows
产品百科 | RTC Windows SDK 音视频设备测试说明
RTC SDK 为您提供音视频设备测试的方法,您可以在音视频通话前检查当前设备上的摄像头,麦克风以及扬声器等音视频设备是否正常工作,以保证音视频通话质量。通过阅读本文,您可以了解音视频设备测试的方法。
产品百科 | RTC Windows SDK 音视频设备测试说明