如何通过Go语言对接语音播报喇叭

如何通过Go语言对接语音播报喇叭呢?

本文描述了使用Go语言调用HTTP接口,对接语音播报喇叭,。

可选用产品:可根据实际场景需求,选择对应的规格
序号设备名称厂商
1智能语音喇叭3友友物联
2智能语音喇叭Mini
3智能语音喇叭86型

下面以每款产品为例,用Go语言编程对接语音播报喇叭:

1. 智能语音喇叭3

远程语音播报、语音提醒、语音通知、语音警报;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒等;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
双发声单元、音量大;
支持远程音量、音色、语调、语速设置;
支持多音字、支持数字(数值、金额、手机号等)读法;
内置铃声、提示音、警示音各5种;
可远程控制环状LED灯带颜色,同时实现视觉提醒;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;
即插即用,无需安装、走线;

更多...


使用Go语言调用HTTP接口控制智能语音喇叭3的代码
以设备控制(向设备下发命令)为例

全部接口文档复制

// 核心请求地址:https://api.yoyoiot.cn/拼接你的AppID的值/device/control/?sign=拼接你计算得到的签名&拼接时间戳也就是计算签名的时候用到的ts;
// 签名为md5(md5(你的开发者密码)拼接上面的ts时间戳的值);ts为时间戳获取当前时间戳即可;也就是将开发者密码(AppSecret)进行一次MD5,然后将这个结果拼接上时间戳,再对整个拼接后的字符串做一次MD5
// 请求需要传递两个参数device和order:
// device[字符串]:设备唯一ID,可传多个[用,间隔],可在控制台可查看,也可通过接口拉取
// order[json字符串]:下发的命令,例如:
// {"power":1},一般为将通断器的线路接通
// {"power3":0},一般为将开关或控制器的第3条线路关闭
// {"play:gbk:16":"你好,欢迎光临"},让语音喇叭播报指定内容
// 相同产品类型的设备,命令相同,不同产品类型的命令,请到每个产品的商品页面查看
// 注意:一定要替换成正式的AppID和AppSecret,再根据实时的时间戳计算签名,请求一定需要device设备ID和order命令

package main

import (
	"bytes"
	"crypto/md5"
	"encoding/hex"
	"encoding/json"
	"fmt"
	"io"
	"net/http"
	"net/url"
	"time"
)

func calculateMD5(s string) string {
	h := md5.New()
	h.Write([]byte(s))
	return hex.EncodeToString(h.Sum(nil))
}

func main() {
	AppID := "开发者ID" // 替换为实际的 AppID
	AppSecret := "开发者密码" // 替换为实际的 AppSecret
	ts := time.Now().Unix() // 获取当前时间戳(秒)

	// 计算签名 md5(md5(开发者密码)拼接上面的ts参数)
	sign := calculateMD5(calculateMD5(AppSecret) + fmt.Sprintf("%d", ts))

	// 构建 URL
	baseURL := fmt.Sprintf("https://api.yoyoiot.cn/%s/device/control/", AppID)
	params := url.Values{}
	params.Add("sign", sign)
	params.Add("ts", fmt.Sprintf("%d", ts))

	// 构建请求体数据
	device := "1878" // 替换为实际的设备ID;可传多个[用,间隔]
	order := map[string]interface{}{"power1": 1} // 替换为实际的命令

	requestBody := map[string]interface{}{
		"device": device,
		"order":  order,
	}

	jsonBody, err := json.Marshal(requestBody)
	if err != nil {
		fmt.Println("Error marshaling JSON:", err)
		return
	}

	// 创建请求
	req, err := http.NewRequest("POST", baseURL+"?"+params.Encode(), bytes.NewBuffer(jsonBody))
	if err != nil {
		fmt.Println("Error creating request:", err)
		return
	}

	req.Header.Set("Content-Type", "application/json")

	// 发送请求
	client := &http.Client{}
	resp, err := client.Do(req)
	if err != nil {
		fmt.Println("Error sending request:", err)
		return
	}
	defer resp.Body.Close()

	// 读取响应
	body, err := io.ReadAll(resp.Body)
	if err != nil {
		fmt.Println("Error reading response:", err)
		return
	}

	fmt.Println("Response Status Code:", resp.StatusCode)
	fmt.Println("Response Body:", string(body))
}

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

2. 智能语音喇叭Mini

远程语音播报、语音提醒、语音通知;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒等;
体积小巧,方便插入、携带;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
支持远程音量、音色、语调、语速设置;
内置铃声、提示音、警示音各5种;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;

更多...


使用Go语言调用HTTP接口控制智能语音喇叭Mini的代码
以设备控制(向设备下发命令)为例

全部接口文档复制

// 核心请求地址:https://api.yoyoiot.cn/拼接你的AppID的值/device/control/?sign=拼接你计算得到的签名&拼接时间戳也就是计算签名的时候用到的ts;
// 签名为md5(md5(你的开发者密码)拼接上面的ts时间戳的值);ts为时间戳获取当前时间戳即可;也就是将开发者密码(AppSecret)进行一次MD5,然后将这个结果拼接上时间戳,再对整个拼接后的字符串做一次MD5
// 请求需要传递两个参数device和order:
// device[字符串]:设备唯一ID,可传多个[用,间隔],可在控制台可查看,也可通过接口拉取
// order[json字符串]:下发的命令,例如:
// {"power":1},一般为将通断器的线路接通
// {"power3":0},一般为将开关或控制器的第3条线路关闭
// {"play:gbk:16":"你好,欢迎光临"},让语音喇叭播报指定内容
// 相同产品类型的设备,命令相同,不同产品类型的命令,请到每个产品的商品页面查看
// 注意:一定要替换成正式的AppID和AppSecret,再根据实时的时间戳计算签名,请求一定需要device设备ID和order命令

package main

import (
	"bytes"
	"crypto/md5"
	"encoding/hex"
	"encoding/json"
	"fmt"
	"io"
	"net/http"
	"net/url"
	"time"
)

func calculateMD5(s string) string {
	h := md5.New()
	h.Write([]byte(s))
	return hex.EncodeToString(h.Sum(nil))
}

func main() {
	AppID := "开发者ID" // 替换为实际的 AppID
	AppSecret := "开发者密码" // 替换为实际的 AppSecret
	ts := time.Now().Unix() // 获取当前时间戳(秒)

	// 计算签名 md5(md5(开发者密码)拼接上面的ts参数)
	sign := calculateMD5(calculateMD5(AppSecret) + fmt.Sprintf("%d", ts))

	// 构建 URL
	baseURL := fmt.Sprintf("https://api.yoyoiot.cn/%s/device/control/", AppID)
	params := url.Values{}
	params.Add("sign", sign)
	params.Add("ts", fmt.Sprintf("%d", ts))

	// 构建请求体数据
	device := "1878" // 替换为实际的设备ID;可传多个[用,间隔]
	order := map[string]interface{}{"power1": 1} // 替换为实际的命令

	requestBody := map[string]interface{}{
		"device": device,
		"order":  order,
	}

	jsonBody, err := json.Marshal(requestBody)
	if err != nil {
		fmt.Println("Error marshaling JSON:", err)
		return
	}

	// 创建请求
	req, err := http.NewRequest("POST", baseURL+"?"+params.Encode(), bytes.NewBuffer(jsonBody))
	if err != nil {
		fmt.Println("Error creating request:", err)
		return
	}

	req.Header.Set("Content-Type", "application/json")

	// 发送请求
	client := &http.Client{}
	resp, err := client.Do(req)
	if err != nil {
		fmt.Println("Error sending request:", err)
		return
	}
	defer resp.Body.Close()

	// 读取响应
	body, err := io.ReadAll(resp.Body)
	if err != nil {
		fmt.Println("Error reading response:", err)
		return
	}

	fmt.Println("Response Status Code:", resp.StatusCode)
	fmt.Println("Response Body:", string(body))
}

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

3. 智能语音喇叭86型

远程语音播报、语音提醒、语音通知、语音警报;
标准86型底盒安装;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒、远程警报等等;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
支持远程音量、音色、语调、语速设置;
内置铃声、提示音、警示音各5种;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;

更多...


使用Go语言调用HTTP接口控制智能语音喇叭86型的代码
以设备控制(向设备下发命令)为例

全部接口文档复制

// 核心请求地址:https://api.yoyoiot.cn/拼接你的AppID的值/device/control/?sign=拼接你计算得到的签名&拼接时间戳也就是计算签名的时候用到的ts;
// 签名为md5(md5(你的开发者密码)拼接上面的ts时间戳的值);ts为时间戳获取当前时间戳即可;也就是将开发者密码(AppSecret)进行一次MD5,然后将这个结果拼接上时间戳,再对整个拼接后的字符串做一次MD5
// 请求需要传递两个参数device和order:
// device[字符串]:设备唯一ID,可传多个[用,间隔],可在控制台可查看,也可通过接口拉取
// order[json字符串]:下发的命令,例如:
// {"power":1},一般为将通断器的线路接通
// {"power3":0},一般为将开关或控制器的第3条线路关闭
// {"play:gbk:16":"你好,欢迎光临"},让语音喇叭播报指定内容
// 相同产品类型的设备,命令相同,不同产品类型的命令,请到每个产品的商品页面查看
// 注意:一定要替换成正式的AppID和AppSecret,再根据实时的时间戳计算签名,请求一定需要device设备ID和order命令

package main

import (
	"bytes"
	"crypto/md5"
	"encoding/hex"
	"encoding/json"
	"fmt"
	"io"
	"net/http"
	"net/url"
	"time"
)

func calculateMD5(s string) string {
	h := md5.New()
	h.Write([]byte(s))
	return hex.EncodeToString(h.Sum(nil))
}

func main() {
	AppID := "开发者ID" // 替换为实际的 AppID
	AppSecret := "开发者密码" // 替换为实际的 AppSecret
	ts := time.Now().Unix() // 获取当前时间戳(秒)

	// 计算签名 md5(md5(开发者密码)拼接上面的ts参数)
	sign := calculateMD5(calculateMD5(AppSecret) + fmt.Sprintf("%d", ts))

	// 构建 URL
	baseURL := fmt.Sprintf("https://api.yoyoiot.cn/%s/device/control/", AppID)
	params := url.Values{}
	params.Add("sign", sign)
	params.Add("ts", fmt.Sprintf("%d", ts))

	// 构建请求体数据
	device := "1878" // 替换为实际的设备ID;可传多个[用,间隔]
	order := map[string]interface{}{"power1": 1} // 替换为实际的命令

	requestBody := map[string]interface{}{
		"device": device,
		"order":  order,
	}

	jsonBody, err := json.Marshal(requestBody)
	if err != nil {
		fmt.Println("Error marshaling JSON:", err)
		return
	}

	// 创建请求
	req, err := http.NewRequest("POST", baseURL+"?"+params.Encode(), bytes.NewBuffer(jsonBody))
	if err != nil {
		fmt.Println("Error creating request:", err)
		return
	}

	req.Header.Set("Content-Type", "application/json")

	// 发送请求
	client := &http.Client{}
	resp, err := client.Do(req)
	if err != nil {
		fmt.Println("Error sending request:", err)
		return
	}
	defer resp.Body.Close()

	// 读取响应
	body, err := io.ReadAll(resp.Body)
	if err != nil {
		fmt.Println("Error reading response:", err)
		return
	}

	fmt.Println("Response Status Code:", resp.StatusCode)
	fmt.Println("Response Body:", string(body))
}

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

产品参数对比

产品 / 版本

参数

智能语音喇叭3

智能语音喇叭Mini

智能语音喇叭86型
白色
白色
白色
外壳材质
塑料
塑料
塑料
产品尺寸
宽:80mm;长:80mm;厚:50mm
宽:65mm;长:65mm;厚:38.4mm
宽:86mm;长:86mm;厚:35mm
产品净重
105g
95g
产品颜色
白色
白色
白色
工作电压
100-250V AC(交流 / 市电)
00-250V AC(交流 / 市电)
100-250V AC(交流 / 市电)
待机功耗
0.4(静音) - 3.7(最大音量播放)W
0.4(静音) - 3.7(最大音量播放)W
0.4(静音) - 3.7(最大音量播放)W
安装方式
2p插头|即插即用
2p插头|即插即用
标准86型底盒安装
无线连接
WiFi IEEE 802.11 b / g / n 2.4GHz
WiFi IEEE 802.11 b / g / n 2.4GHz
WiFi IEEE 802.11 b / g / n 2.4GHz
产品外壳
防火V0级PC,耐高温,符合安规标准
防火V0级PC,耐高温,符合安规标准
防火V0级PC,耐高温,符合安规标准
包装清单
智能语音喇叭*1
智能语音喇叭*1
智能语音喇叭*1 、 螺丝钉*2

产品尺寸与走线

1. 智能语音喇叭3接线示意图

2. 智能语音喇叭Mini接线示意图

3. 智能语音喇叭86型接线示意图

走线示意


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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值