张 腾,金 光,江先亮,朱家骅
(宁波大学 信息科学与工程学院,浙江 宁波 315211)
随着物联网及嵌入式技术的发展,物联网应用已遍布各行各业,物联网应用开发教学也成为了当前信息技术教育的主流内容之一.不同于其他工程开发,物联网应用开发中硬件及接口的差异化会造成学习者在设备选型、线路连接、环境部署时的困难,进一步增加了学习成本及开发周期.
目前主流的快速物联网开发平台大多采用浏览器端编写代码,云端服务器进行编译并烧录程序的方式.其中,OElab 采用B/S及C/S两种架构结合云端编译器及管理器,实现了电源管理、代码下载及视频监控等功能[1].该平台针对专业嵌入式开发人员,能够有效降低相关的测试及开发门槛,但仍需在本地进行代码编写,然后进行云端编译并下载代码运行.ARM mbed 可以完成基于ARM 系列内核的开发板编程工作,采用浏览器端代码编写并完成编译,编译后的文件由本地PC 端程序存入开发板并完成代码运行[2].Arduino Web Editor 是一款针对于Arduino 开发套件的浏览器编程方案,免去了开发环境的安装,但需要通过浏览器插件进行设备连接及下载,对系统及浏览器版本有一定要求[3].Tinyink 注重于降低初学者的硬件学习成本,根据用户代码采用智能决策算法来生成所需的硬件及其连接方案,免去了用户设备选型的麻烦[4].但该系统需用户本地进行代码编写及硬件开发,不适用于初学者.micro:bit 是一款针对于低龄物联网及嵌入式学习者的实验套件,目前支持网页端的图形化编程及Python语言编程[5].该系统通过浏览器页面编程,并将二进制文件下载到本地,然后通过本地工具烧录进开发板中.该系统有较好的模块化设计,但仍需在本地安装驱动及软件.LinkLab 通过浏览器页面进行代码编写,并在云端完成编译,编译后的文件发送给远程终端设备,再通过串口完成物联网设备烧录[6].该方式适用于面向软件编程的用户,缺少了硬件编程的直观性和趣味性.
综上所述,目前缺乏一款面向初学者的免环境安装、接口统一、步骤简单、系统稳定可靠的物联网在线开发平台,使初学者能更好地学习业务逻辑开发,了解软件驱动与硬件之间的关系,而不必在意开发及硬件烧录过程中的繁琐步骤.因此,本文设计了面向云环境的敏捷物联网应用开发平台,该平台是一个屏蔽硬件差异化的分布式远程物联网应用开发平台,没有代码编译过程,无需任何辅助设备及软件,用户可直接在浏览器端进行物联网开发、实验及教学.并且平台实现了在线编程、一键运行的功能,达到了屏蔽硬件、忽略差异化的目的.
与上述技术及系统采用的硬件完全抽象化及部分步骤精简化不同,本文进一步分析了用户在学习及开发时的需求,将物联网开发中不太相关的繁琐部分进行了抽象化,并完整地保留对学习及开发者有用的部分,使得本方案能够有效地保证学习的完整性及高效性.
如图1 所示,本平台与其他方案及系统相比,将环境安装、代码烧录等与物联网开发技术关联不强的繁琐程序进行抽象化,转移到云端平台进行.同时,针对于能够锻炼用户开发及具备有效体验实验效果的WebIDE 及模块化开发板对用户可见.所以,本平台能够在极大地减少用户使用成本的同时,给予用户完整的物联网开发体验及流程,更便于用户了解物联网开发学习及实验时所需的知识点及操作步骤.
图1 平台可视化示意图
平台采用B/S 架构,用户在浏览器端进行线上物联网实验及开发.相应系统架构如图2 所示,平台分为应用层、服务层、设备层.应用层采用在线集成开发环境(Web Integrity Develop Environment,WebIDE)方式,在有效降低用户使用难度、减少学习成本的同时,达到跨平台的目的.服务层选用微服务架构[7]进行设计和搭建,相比其他架构拥有更好的鲁棒性及扩展性,能够更好地满足用户的功能需求.设备层主要由配套实验开发板及实验模块组成,该实验套件具有接口统一、易用的特点,更加便于用户的学习及开发.
图2 平台系统架构
平台主要工作流程如图3 所示.当用户将通过应用层浏览器编写完成之后的代码传送给服务层的云端微服务,其中的代码推送服务负责将代码从服务器推送到设备层开发板.手机APP 用于第一次使用时对开发板的初始化配置工作.
图3 系统工作流程概述
本系统无需编译流程,具体代码运行及反馈流程如图4 所示.步骤1:用户在WebIDE 编写完代码之后,前端服务通过HTTP 协议将代码发送给图3 服务层所示的一对一推送服务.步骤2:一对一推送服务对代码进行语法处理后,将代码通过MQTT 服务器推送给开发板.步骤3:开发板运行Python 代码后,通过控制I/O 引脚完成物理上的实验现象演示.步骤4:通过MQTT 协议将实验结果反馈给物联网开发服务.步骤5:物联网开发服务将数据进行格式化处理后,通过WebSocket 协议将代码运行结果反馈给前端服务器,并在前端页面显示出来.
图4 代码运行及反馈流程
本平台主要功能如下:
(1)应用层及服务层设计与开发.应用层主要由前端页面及前端服务构成,包括登录注册功能的设计与开发、WebIDE 功能的设计与开发、用户中心功能的设计与开发.
服务层主要是后端微服务设计与开发,包括基于Spring Cloud 架构进行系统架构设计,完成微服务相关组件搭建,完成鉴权认证服务、物联网开发服务、用户信息服务及一对一代码推送服务的设计与开发.
应用层前端功能与服务层对应服务见表1.
表1 应用层与服务层对应关系表
(2)物联网代码推送机制设计.旨在设计一种能够连接后端服务与开发板的推送机制,该机制以微服务形式部署在线上编程系统的服务器端.
(3)设备层实验开发板设计与制作.开发板设计与制作需针对功能要求进行PCB(印刷电路板)的设计及制作,并根据电路原理图完成开发板及相关外设的驱动开发及固件烧录.
针对于实验开发板参数初始化需要,完成基于蓝牙通信手机的配套APP 编写.
本系统核心内容包括三部分:(1)设计适用于物联网开发环境下的一对一推送机制;(2)设计和实现支持拓展的易用性物联网实验套件;(3)设计基于TEA 加密算法[8]的动态口令认证协议[9].
满足高并发和一对一(一个用户针对一套开发板)的通信需要是本系统的关键点,传统TCP 连接服务器在合法性检测、确认重传机制的设计、对高并发量的支持等方面都无法满足实际需求.此外,适于物联网设备的MQTT 协议虽具有消耗小、高并发的特点[10],但其协议采用发布/订阅的模式,适于一对多通信的场景,无法满足一对一通信要求.针对此应用场景,本文设计了一种基于MQTT的一对一代码推送机制.
如图5 所示,在对开发板进行配网时,配网软件会获取开发板的唯一ID,当与用户ID 进行绑定后,存储到数据库中.配网完成后,开发板会订阅以自身ID+“00”命名的主题,发布以自身ID 为主题的广播.用户完成线上代码编写,并将代码发送至物联网服务器,后端服务通过读取数据库以获取开发板ID,创建以开发板ID+“00”为主题的广播进行代码传输,订阅以开发板ID 命名的主题完成开发板运行信息的接收,达到双向一对一通信的目的.
图5 一对一代码推送机制流程
为实现用户代码完成推送后自动在开发板上的运行,本文设计的开发板采用MicroPython 系统为底层固件.MicroPython 是Python 3 语言的精简高效实现,可在微控制器和受限环境中运行[11].因Python 为解释性语言,开发板在接收代码后,可直接调用此Python 代码,实现自动运行功能.
开发板设计及开发架构如图6 所示.以ESP32为核心,且根据需要可更换不同性能的芯片,如stm32、ARM 系列Soc 等.此外,还根据功能需要设计了外设电路及外设模块,且实验板与外设之间采用易用性接口连接.
图6 开发板硬件系统结构
对于本场景,本文针对主板的充电、稳压供电、下载通信、外设驱动等电路进行了重新设计,其中开发板的主控芯片电路如图7 所示.
图7 主控芯片电路图
为防止非法设备接入及网络漏洞导致用户信息泄露等问题,结合开发板核心性能不高的限制,本文设计了一种基于TEA 加密算法的动态口令认证协议.
该协议选用时间同步方式作为不确定因子,采用SHA256 哈希算法和TEA 加密算法完成认证及传输加密,以进一步提高系统安全性和破解难度,本认证协议符号和相关表示见表2.
表2 认证协议算法符号和标识
本文选用CID、CB_MAC、CW_MAC 组合,并经过SHA256 加密之后作为请求信息,公式如下:
在发送请求信息时,将开发板获取的TC、CID信息进行TEA 加密操作,得到REQSE作为加密请求数据,公式如下:
服务器接收到请求信息后,对数据进行解密操作,公式如下:
执行过程如图8 所示.步骤1:开发板Ci向时间同步服务器ST获取时间.步骤2:开发板将CID、TC数据与SHA256 加密后的CID、CB_MAC、CW_MAC 组合数据作为请求数据,经过TEA 加密算法加密后,向认证服务器发出请求.步骤3:服务器解密获取TC、CID 及REQSE数据,校验TC,并比对数据库中的REQSE数据,完成开发板认证.步骤4:服务器将TS以及SHA256 加密后的CID、CB_MAC、CW_MAC 数据发送给开发板.步骤5:开发板验证TS以及解压后的REQSE.
图8 双向口令认证流程
平台开发完成后,我们将软硬件系统进行了部署.软件部分,在内存为32 GB、CPU 为E5-2630 V3 的服务器上使用19.03.5 版本Docker 容器化部署了线上编程系统各项服务,使用Android 6.0.1 系统安装了蓝牙配网App.硬件部分,运行平台为
我们以按键与指示灯外设模块为例进行实验测试,以验证本方案主控电路、外设电路接口方案的可行性.该外设模块使用易用性接口,能更方便地完成安装和卸载工作.具体开发板电路如图9(a)所示,外设模块电路如图9(b)所示,安装有外设模块的开发板实物如图9(c)所示.目前,本系统已实现的实验套件外设模块见表3.
图9 开发板、外设电路及实物
表3 目前已实现外设模块
用户完成登录后,进入线上编程界面,输入测试代码,并点击运行按钮开始运行程序.待程序成功运行后,可以看到如图10 所示的实验现象:开发模块上的红、黄、绿3 种颜色LED 灯以1s 的间隔进行周期性闪烁.
图10 配套物联网开发实验效果
本文方案与LinkLab、Arduino Web Editor、Arm Mbed 等系统的功能进行了对比.由表4 可见,本系统具有跨设备、无需编译、无需软硬件辅助设备等优点,能明显降低使用难度、提升用户体验.
表4 本平台与主流系统功能对比
当前物联网应用系统开发门槛高、开发环境复杂,导致物联网开发相关课程的实验教学难以在线上开展,针对该类问题,我们设计并实现了一套基于微服务架构的线上物联网实验平台.考虑到已有通信协议无法满足实际需求,同时设计了一种新的基于MQTT 的一对一推送机制.并根据实际需求,设计并制作了一款基于ESP32 的物联网开发板及手机端配网APP.此外,设计了一种基于TEA加密算法的动态口令认证协议,以进一步保障设备及用户信息的安全.经过系统部署及实际功能测试,表明该系统方案能够有效完成预期功能,具有较好的实用价值,为工科类尤其是物联网嵌入式课程开展线上实验教学提供了一种新的方案.未来我们将针对该平台进一步深化设计细节,拓展应用场景,提升用户体验,使其逐步得以广泛应用.