怎样用Go语言实现远程控制三路开关呢?
本文描述了使用Go语言调用HTTP接口,实现远程控制三路开关,三路开关可控制三路照明、排风扇等电器。
可选用产品:可根据实际场景需求,选择对应的规格
序号 | 设备名称 | 厂商 |
---|---|---|
1 | 智能墙壁开关3路 | 友友物联 |
2 | 智能触摸墙壁开关3路 |
下面以每款产品为例,用Go语言编程实现远程控制三路开关:
1. 智能墙壁开关3路
标准86型底盒安装,可直接平行替换原有墙壁开关;
可独立控制3路照明或其他电器;
3路分控,均可通过HTTP接口独立远程;
支持远程定时任务,支持自定义联动操作;
可保持(锁定)开关状态,用户操作后若干秒,恢复原有状态;
使用Go语言调用HTTP接口控制智能墙壁开关3路的代码
以设备控制(向设备下发命令)为例
全部接口文档复制
package main
import (
"fmt"
"io/ioutil"
"net/http"
"net/url"
"strings"
)
func main() {
body, err := request()
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}
func request() ([]byte, error) {
uri := "https://api.yoyoiot.cn/{AppID}/device/control/?sign={sign}&ts={ts}"
payload := url.Values{}
payload.Set("device", "设备ID")
payload.Set("order", "命令")
/*
device[字符串]:设备唯一ID,可传多个,可在控制台可查看,也可通过接口拉取;
order[json字符串]:命令,取值参考:
1. 线路1 - 可用值[1(开),0(关)]
示例[关], order为:{"power1":"0"}
2. 线路2 - 可用值[1(开),0(关)]
示例[关], order为:{"power2":"0"}
3. 线路3 - 可用值[1(开),0(关)]
示例[关], order为:{"power3":"0"}
4. 1路状态保持 - 可用值[{"keep":"0","revert":"3"}(1路保持关(用户开3秒后自动关闭)),{"keep":"1","revert":"3"}(1路保持开(用户关3秒后自动打开))]
示例[1路保持开(用户关3秒后自动打开)], order为:{"power1":{"keep":"1","revert":"3"}}
5. 2路状态保持 - 可用值[{"keep":"0","revert":"3"}(2路保持关(用户开3秒后自动关闭)),{"keep":"1","revert":"3"}(2路保持开(用户关3秒后自动打开))]
示例[2路保持开(用户关3秒后自动打开)], order为:{"power2":{"keep":"1","revert":"3"}}
6. 3路状态保持 - 可用值[{"keep":"0","revert":"3"}(3路保持关(用户开3秒后自动关闭)),{"keep":"1","revert":"3"}(3路保持开(用户关3秒后自动打开))]
示例[3路保持开(用户关3秒后自动打开)], order为:{"power3":{"keep":"1","revert":"3"}}
7. 1路先通后断 - 自定义
示例[2s], order为:{"point1":"2000"}
8. 2路先通后断 - 自定义
示例[2s], order为:{"point2":"2000"}
9. 3路先通后断 - 自定义
示例[2s], order为:{"point3":"2000"}
10. 1路先断后通 - 自定义
示例[2s], order为:{"reset1":"2000"}
11. 2路先断后通 - 自定义
示例[2s], order为:{"reset2":"2000"}
12. 3路先断后通 - 自定义
示例[2s], order为:{"reset3":"2000"}
*/
req, _ := http.NewRequest("POST", uri, strings.NewReader(payload.Encode()))
req.Header.Add("X-APISpace-Token","")
req.Header.Add("Content-Type","")
res, err := http.DefaultClient.Do(req)
if err != nil {
return nil, err
}
defer res.Body.Close()
return ioutil.ReadAll(res.Body)
}
说明:{AppID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档。
2. 智能触摸墙壁开关3路
使用Go语言调用HTTP接口控制智能触摸墙壁开关3路的代码
以设备控制(向设备下发命令)为例
全部接口文档复制
package main
import (
"fmt"
"io/ioutil"
"net/http"
"net/url"
"strings"
)
func main() {
body, err := request()
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}
func request() ([]byte, error) {
uri := "https://api.yoyoiot.cn/{AppID}/device/control/?sign={sign}&ts={ts}"
payload := url.Values{}
payload.Set("device", "设备ID")
payload.Set("order", "命令")
/*
device[字符串]:设备唯一ID,可传多个,可在控制台可查看,也可通过接口拉取;
order[json字符串]:命令,取值参考:
1. 线路1 - 可用值[1(开),0(关)]
示例[关], order为:{"power1":"0"}
2. 线路2 - 可用值[1(开),0(关)]
示例[关], order为:{"power2":"0"}
3. 线路3 - 可用值[1(开),0(关)]
示例[关], order为:{"power3":"0"}
4. 1路状态保持 - 可用值[{"keep":"0","revert":"2"}(1路保持关(用户开2秒后自动关闭)),{"keep":"1","revert":"3"}(1路保持开(用户关3秒后自动打开))]
示例[1路保持开(用户关3秒后自动打开)], order为:{"power1":{"keep":"1","revert":"3"}}
5. 2路状态保持 - 可用值[{"keep":"0","revert":"2"}(2路保持关(用户开2秒后自动关闭)),{"keep":"1","revert":"3"}(2路保持开(用户关3秒后自动打开))]
示例[2路保持开(用户关3秒后自动打开)], order为:{"power2":{"keep":"1","revert":"3"}}
6. 3路状态保持 - 可用值[{"keep":"0","revert":"2"}(3路保持关(用户开2秒后自动关闭)),{"keep":"1","revert":"3"}(3路保持开(用户关3秒后自动打开))]
示例[3路保持开(用户关3秒后自动打开)], order为:{"power3":{"keep":"1","revert":"3"}}
7. 1路先通后断 - 可用值[1000(1s),2000(2s),5000(5s)]
示例[2s], order为:{"point1":"2000"}
8. 2路先通后断 - 可用值[1000(1s),2000(2s),5000(5s)]
示例[2s], order为:{"point2":"2000"}
9. 3路先通后断 - 可用值[1000(1s),2000(2s),5000(5s)]
示例[2s], order为:{"point3":"2000"}
10. 1路先断后通 - 可用值[1000(1s),2000(2s),5000(5s)]
示例[2s], order为:{"reset1":"2000"}
11. 2路先断后通 - 可用值[1000(1s),2000(2s),5000(5s)]
示例[2s], order为:{"reset2":"2000"}
12. 3路先断后通 - 可用值[1000(1s),2000(2s),5000(5s)]
示例[2s], order为:{"reset3":"2000"}
*/
req, _ := http.NewRequest("POST", uri, strings.NewReader(payload.Encode()))
req.Header.Add("X-APISpace-Token","")
req.Header.Add("Content-Type","")
res, err := http.DefaultClient.Do(req)
if err != nil {
return nil, err
}
defer res.Body.Close()
return ioutil.ReadAll(res.Body)
}
说明:{AppID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档。
产品参数对比
产品 / 版本 参数 |
智能墙壁开关3路 |
智能触摸墙壁开关3路 |
---|---|---|
白色 |
白色 |
|
外壳材质 |
塑料 |
钢化玻璃 |
产品尺寸 |
宽:86mm;长:86mm;厚:41mm |
宽:86mm;长:86mm;厚:35mm |
产品净重 |
95g |
95g |
产品颜色 |
白色 |
白色 |
控制路数 |
3路 |
3路 |
操控方式 |
按键 |
触摸 |
工作电压 |
100-240V AC(交流 / 市电) |
100-240V AC(交流 / 市电) |
额定电流 |
10A |
10A |
负载功率 |
300-1200W |
300-1200W |
待机功耗 |
0.4(全断) - 1.7(全通 / 无负载)W |
0.4(全断) - 1.7(全通 / 无负载)W |
安装方式 |
标准86型底盒安装 |
标准86型底盒安装 |
无线连接 |
WiFi IEEE 802.11 b / g / n 2.4GHz |
WiFi IEEE 802.11 b / g / n 2.4GHz |
产品外壳 |
防火V0级PC,耐高温,符合安规标准 |
防火V0级PC,耐高温,符合安规标准 |
包装清单 |
智能墙壁开关*1 、 电容*1 、 螺丝钉*2 |
智能墙壁开关*1 、 电容*1 、 螺丝钉*2 |
产品尺寸与走线
1. 智能墙壁开关3路接线示意图
走线示意
* 接线前请确保断路器上的电源已关闭
2. 智能触摸墙壁开关3路接线示意图