如何用Go语言实现远程控制门锁

如何用Go语言实现远程控制门锁呢?

本文描述了使用Go语言调用HTTP接口,实现控制门锁,通过智能出门开关,配合普通的电插锁、电磁锁,来实现门禁控制。

可选用产品:可根据实际场景需求,选择对应的规格
序号设备名称厂商
1智能WiFi墙壁出门开关统软云物联
2智能WiFi触摸墙壁出门开关

下面以每款产品为例,用编程实现远程:

1. 智能WiFi墙壁出门开关

标准86型底盒,安装简单;
可接任何种类的电磁锁、电插锁;
广泛应用于各种门禁控制、门禁改造;
支持断电开锁|通电上锁、支持断电上锁|通电开锁 两种模式;
HTTP接口远程控制通断;
支持远程定时任务,支持自定义联动操作;

更多...


使用调用HTTP接口控制智能WiFi墙壁出门开关的代码
以设备控制(向设备下发命令)为例

全部接口文档复制

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 := "http://iot-api.unisoft.cn/{APP_ID}/device/control/?sign={sign}&ts={ts}"

    payload := url.Values{}
	payload.Set("device", "设备ID")
	payload.Set("order", "命令")

/*
device[字符串]:设备唯一ID,可传多个,可在控制台可查看,也可通过接口拉取;
order[json字符串]:命令,取值参考:
1. 开关 - 可用值[0(关),1(开)]
   示例[开], order为:{"power":"1"}
2. 先断后通 - 自定义
   示例[3秒], order为:{"reset":"3000"}
3. 先通后断 - 自定义
   示例[3秒], order为:{"point":"3000"}
*/

    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)
}

说明:{APP_ID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档

2. 智能WiFi触摸墙壁出门开关

更多...


使用调用HTTP接口控制智能WiFi触摸墙壁出门开关的代码
以设备控制(向设备下发命令)为例

全部接口文档复制

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 := "http://iot-api.unisoft.cn/{APP_ID}/device/control/?sign={sign}&ts={ts}"

    payload := url.Values{}
	payload.Set("device", "设备ID")
	payload.Set("order", "命令")

/*
device[字符串]:设备唯一ID,可传多个,可在控制台可查看,也可通过接口拉取;
order[json字符串]:命令,取值参考:
1. 开关 - 可用值[0(关),1(开)]
   示例[开], order为:{"power":"1"}
2. 先断后通 - 可用值[2000(2秒),3000(3秒),5000(5秒)]
   示例[3秒], order为:{"reset":"3000"}
3. 先通后断 - 可用值[2000(2秒),3000(3秒),5000(5秒)]
   示例[3秒], order为:{"point":"3000"}
*/

    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)
}

说明:{APP_ID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档

产品参数对比

产品版本

智能WiFi墙壁出门开关
白色

智能WiFi触摸墙壁出门开关
白色

产品尺寸与走线

1. 智能WiFi墙壁出门开关接线示意图

产品尺寸


走线示意

* 接线前请确保断路器上的电源已关闭

切记,请勿直接将电插锁接在出门开关上!

2. 智能WiFi触摸墙壁出门开关接线示意图

产品尺寸


走线示意

* 接线前请确保断路器上的电源已关闭

切记,请勿直接将电插锁接在出门开关上!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值