CATALOG

芯步的2路智能墙壁开关开放了标准的HTTP接口,不管你的项目是用Python、Node.js还是PHP写的,都能通过简单的API调用实现独立控制两路灯具。下面直接说怎么接、怎么写代码、要注意啥。

一、核心准备:先搞定“钥匙”与“门牌号”

在写代码之前,你需要先去芯步的开放平台控制台拿到两样东西,这就像是你进门的钥匙和门牌号:

  1. AppID (应用ID):这是你的“项目身份证”,平台通过它来识别是你的应用在调用接口。

  2. Device ID (设备ID):这是你那个2路开关的ID。注意,开关本身是一个设备,但这个设备里面有两个独立的“通道”(channel)。你需要把这个ID抄下来,告诉程序你要控制哪个开关。

二、实战演练:如何用代码“按下”开关

芯步的接口设计得很直白,你可以直接用 HTTP POST 的方式去控制。这里我直接拿最常用的场景举例:通过服务器后端(比如Python)或云函数来控制。

接口地址(Endpoint):https://api.thingboot.com/{你的AppID}/device/control/?sign={签名}&ts={时间戳}

核心逻辑:通过改变 order 参数里的 power1power2 的值,来分别控制第一路和第二路。

1. 最简单的操作:单独关掉第2路(比如关掉射灯)

假设店里太热,你想把发热量大的射灯关掉,但留着基础照明。

  • 命令指令:{"power2":"0"}

    • power2 代表第二路。

    • 0 代表关闭,1 代表开启。

  • 请求示例(Python + requests库):

2. 批量控制:同时打开第1路和第2路(比如营业高峰期)

早上10点开店,需要所有灯全亮。

  • 命令指令:{"power1":"1", "power2":"1"}

3. 进阶玩法:脉冲模式(先通后断)——控制排气扇或临时测试

有时候你需要让设备通电5秒钟然后自动断开(比如控制门禁、电锁或者短暂触发某个设备)。芯步的接口直接支持“点动”模式,不用你在代码里写延时和循环,硬件自己会处理。

  • 命令指令:{"point1":"2000"}

    • 这代表:让第一路先接通,2秒后自动断开。

    • 2000 单位是毫秒(ms),也就是2秒。

三、把这些接口“集成”到你的项目里

接口调通了,怎么把它变成你项目里的一个功能按钮呢?其实很简单,无论你是做微信小程序PC管理后台还是手机APP,流程都是一样的:

  1. 前端页面:画两个开关按钮(UI可以做得很好看),一个叫“主照明”,一个叫“橱窗射灯”,再加一个“全开/全关”。

  2. 前端逻辑:当用户点击“打开主照明”时,前端发起一个Ajax请求到你的后端服务器

  3. 后端逻辑:你的后端接收到请求后,直接调用上面的Python代码(或者Node.js/Java代码),将数据发给芯步的云端。

  4. 云端下发:芯步的服务器收到指令后,通过WiFi推送到你店里的那个物理开关上。

给你的项目架构小:虽然你可以从前端直接调用云API,但千万不要把AppID和密钥写在小程序或APP的代码里,那样会被别人反编译盗用。正确做法是:前端 -> 你的后端 -> 芯步云端

四、必看的避坑指南

在实际集成中,有几个点如果你不注意,可能会坑到自己:

  1. 返回值200不等于操作成功这是新手最容易晕的地方。返回200只代表芯步的服务器收到了指令,不代表你的灯真的亮了如果你的灯没反应,大概率是设备离线了(WiFi断了)或者设备ID填错了。记得处理一下异步消息推送,或者看下控制台的设备日志。

  2. 两路开关的独立性与功率限制这两个开关是完全隔离的,你可以控制一路关一路开。但注意,每一路都有最大功率限制(一般是几百瓦到一千多瓦,具体看型号)。不要在一个回路里接太多大功率灯具,容易烧坏硬件。

  3. 状态同步问题如果有人手动按了墙上的物理开关,你的APP界面显示是“关”,实际上灯是“开”的,这就不同步了。解决办法:让你的后端每隔一段时间去查询一次设备状态,或者让设备在状态变化时主动上报,推送给前端刷新。

  4. 网络要求这种开关只支持 2.4G WiFi,不支持5G频段。如果店铺里有那种双频合一的信号,最好把手机或电脑的5G频段忽略掉,先配网连上2.4G。

总结

把芯步的2路开关集成到你的项目中,本质上就是调用了一次HTTP接口

  • 控制第1路order 里传 power1

  • 控制第2路order 里传 power2

  • 点动模式:传 point1 / point2(单位毫秒)

这种硬件的价值在于,它通过简单的API把“软件”和“强电硬件”中间的鸿沟填平了,让开发者不需要懂电路,也能写出控制220V市电的代码。