英特尔物联网代码示例入门: 访问控制
简介这款访问控制系统应用是一系列英特尔物联网代码示例入门实践(使用英特尔® 物联网开发人员套件、英特尔® Edison 开发平台、API 和其他技术)的一部分。从该实践中,开发人员可以学习到如何:[*]连接英特尔® Edison 开发平台;该平台是一个旨在创建原型,生产物联网和可穿戴计算产品的计算平台。
[*]使用英特尔® 物联网开发人员套件中的 MRAA 和 UPM 与英特尔® Edison 平台 IO 和传感器库交互;该套件是一款完整的软硬件解决方案,可帮助开发人员探索物联网和实施创新项目。
[*]在英特尔® XDK 物联网版中运行该代码示例;该工具是一个 IDE,可创建与传感器和制动器交互的应用,支持立即开发面向英特尔® Edison 或英特尔® Galileo 开发板的软件。
[*]使用 Microsoft* 的 Azure* Redis Cache 、IBM Bluemix* 的 Redis Store 或使用 Amazon* Web Services* (AWS) 的 Redis* 的 ElastiCache*,连接物联网解决方案(包括数据分析、机器学习和各种生产力工具)的不同云服务以简化将传感器连接到云,支持物联网项目快速正常运行的效率提高工具,设置 Web 应用服务器以支持用户输入访问代码来禁用报警系统并保存该报警数据。
它是什么
使用英特尔® Edison 开发板,该项目为您介绍如何创建具备以下功能的智能访问控制系统:
[*]监控运动传感器,以检测有人已进入要求授权的的区域;
[*]支持使用手机通过内置 Web 界面访问以禁用报警系统;
[*]使用基于云的数据存储跟踪访问。
工作原理
该控制访问系统提供以下用户工作流:
[*]被动红外 (PIR) 运动传感器查看运动。
[*]用户引发动作检测器,然后有 30 秒的时间在浏览器中输入正确的代码。
[*]如果用户没有按时输入代码,将发出警告。
[*]如果用户输入了正确的代码,系统将等待 30 秒以允许用户通过。
另外,各种不同的事件(looking-for-motion、motion-detected、invalid-code等)也将会记录下来。此外,它还可使用在 Microsoft* Azure* 账户中运行的英特尔物联网示例数据存储 (Intel IoT Example Datastore) 保存所有数据。
硬件要求
Grove* 交通安全工具包,包括:
[*]带有 Arduino* breakout 开发板的英特尔® Edison
[*]Grove* PIR 运动传感器
[*]Grove* RGB LCD
软件要求
[*]英特尔® XDK 物联网版
[*]Microsoft* Azure* 账户
如何设置
首先,使用电脑上的 Git*(如下)复制英特尔物联网代码示例入门库:$ git clone https://github.com/intel-iot-devkit/how-to-code-samples.git想要下载 .zip 文件? 在您的 Web 浏览器中,访问 https://github.com/intel-iot-devkit/how-to-code-samples,并点击右下方的 Download ZIP 按钮。 下载 .zip 文件后,对其进行解压,然后使用目录中的文件(对本例而言)。
将该程序添加至英特尔® XDK 物联网版
在英特尔® XDK 物联网版中,选择 Import Your Node.js Project:
然后,导航至该示例项目所在的目录,并选择它:
您需要将电脑连接至您的英特尔® Edison 开发板以向其发送代码。
点击左下角的 IoT Device 菜单。 如果您的英特尔® Edison 被自动识别,选择它。
否则,选择 Add Manual Connection。 在 Address 字段,键入 192.168.2.15。 在 Port 字段,键入 58888。 点击 Connect 以保存连接。
在英特尔® Edison 上手动安装该程序
或者,您可以在英特尔® Edison 开发板上手动设置代码。与您的英特尔® Edison 开发板建立 SSH 连接,然后将英特尔物联网代码示例入门库复制到该开发板中,如下:$ git clone https://github.com/intel-iot-devkit/how-to-code-samples.git然后,导航至该目录(对本例而言)。如欲在英特尔® Edison 上安装 Git*(若没有),请与该开发板建立 SSH 连接,并运行下列命令:$ opkg install git
连接传感器
您需要具有连接至兼容 Arduino* 的 breakout 开发板的 Grove* Shield,以便将所有 Grove* 设备插入 Grove* Shield。 确保 Grove* Shield 上的微型 VCC 开关设置为 5V。
[*]将 Grove* 线缆的一端插入 Grove* PIR 运动传感器,并将其另一端连接至 Grove* Shield 的 D4 端口上。
[*]将 Grove* 线缆的一端插入 Grove* RGB LCD,并将其另一端连接至 Grove* Shield 的任意 I2C 端口上。
英特尔® Edison 手动设置如果您在英特尔® Edison 上手动运行该代码,您需要安装一些关联组件。如欲获得在英特尔® Edison 上执行该示例所需的 Node.js* 模块,请运行下列命令:npm install
Microsoft* Azure* 服务器设置您还可选择将该示例程序生成的数据存储在使用 Microsoft* Azure*、Node.js* 和 Redis* 数据存储部署的后端数据库中。有关如何设置云数据服务器的信息,请访问:https://github.com/intel-iot-devkit/intel-iot-examples-datastore
配置该示例如欲配置该示例以使用可选的 Microsoft* Azure* 数据存储,请修改 SERVER 和 AUTH_TOKEN 密钥(在 config.json 文件中,如下:{ "SERVER": "http://intel-examples.azurewebsites.net/logger/access-control", "AUTH_TOKEN": "s3cr3t" }
使用英特尔® XDK 物联网版运行该程序准备好运行该示例时,确保保存了所有文件。
点击 Upload 图标,将文件上传至英特尔® Edison 开发板。
点击英特尔® XDK 物联网版底部的 Run 图标, 在英特尔® Edison 上运行该代码。
如果您修改了该代码,请点击 Upload and Run, 在英特尔® Edison 上运行包含您所做修改的最新代码。
https://github.com/intel-iot-devkit/how-to-code-samples/raw/master/images/js/access-control-output.png当该程序在运行时,您会看到与上述内容类似的输出信息。
手动运行该程序
如欲在英特尔® Edison 上手动运行该程序,请与该开发板建立 SSH 连接,并执行下列命令:node index.js
禁用报警系统https://github.com/intel-iot-devkit/how-to-code-samples/raw/master/images/js/access-control-web.png使用该示例程序运行时英特尔® Edison 开发板显示的单页 Web 界面禁用报警系统。该 Web 服务器运行在端口 3000 上,因此,如果英特尔® Edison 连接至 192.168.1.13 上的Wi-Fi*,您在同一网络上时浏览的地址是 http://192.168.1.13:3000。
确定英特尔® Edison 的 IP 地址
您可以通过运行下列命令确定英特尔® Edison 所连接的 IP 地址:ip addr show | grep wlan您会看到与下列内容相似的输出信息:3: wlan0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000 inet 192.168.1.13/24 brd 192.168.1.255 scope global wlan0IP 地址显示在 inet 旁边。 在上述示例中,IP 地址为 192.168.1.13。如欲查看英特尔物联网代码示例入门的完整列表,请访问英特尔开发人员专区。有关该代码示例的更多详情,请访问 GitHub*。
https://mc.dfrobot.com.cn/data/attachment/forum/201611/16/165545rhaal9loa1alapnp.jpg
更多英特尔物联网信息请点击右边链接直接登录 >>>>英特尔® Edison 模块 | 物联网
页:
[1]