怎么用Java语言对接语音提示音箱呢?
本文描述了使用Java语言调用HTTP接口,对接语音提示音箱,。
可选用产品:可根据实际场景需求,选择对应的规格
序号 | 设备名称 | 厂商 |
---|---|---|
1 | 智能语音音柱|10W | 友友物联 |
2 | 智能语音壁挂音箱|款式1 | |
3 | 智能语音吸顶音箱 |
下面以每款产品为例,用Java-Unirest编程对接语音提示音箱:
1. 智能语音音柱|10W
远程语音播报、语音提醒、语音通知、语音警报;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒等;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
支持远程音量、音色、语调、语速设置;
支持多音字、支持数字(数值、金额、手机号等)读法;
内置铃声、提示音、警示音各5种;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;
防尘防水,外形美观,安装简单;
使用Java语言调用HTTP接口控制智能语音音柱|10W的代码
以设备控制(向设备下发命令)为例
全部接口文档复制
// 核心请求地址: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命令
/*首先,确保在你的项目中添加了 unirest 的 Maven 依赖。如果你使用的是 Maven,可以在 pom.xml 中添加以下依赖:
<dependency>
<groupId>com.konghq</groupId>
<artifactId>unirest-java</artifactId>
<version>3.13.10</version>
</dependency>
*/
import com.konghq.unirest.http.HttpResponse;
import com.konghq.unirest.http.Unirest;
import com.konghq.unirest.http.exceptions.UnirestException;
import org.apache.commons.codec.digest.DigestUtils;
public class Main {
public static void main(String[] args) {
// 定义变量
String AppID = "开发者ID"; // 替换为实际的 AppID
String AppSecret = "开发者密码"; // 替换为实际的 AppSecret
long ts = System.currentTimeMillis() / 1000; // 获取当前时间戳(秒)
// 计算签名 md5(md5(开发者密码)拼接上面的ts参数)
String sign = DigestUtils.md5Hex(DigestUtils.md5Hex(AppSecret) + ts);
// 构建 URL
String url = String.format("https://api.yoyoiot.cn/%s/device/control/?sign=%s&ts=%d", AppID, sign, ts);
// 请求体数据
String device = "1878"; // 替换为实际的设备ID;可传多个[用,间隔]
String order = "{\"power1\":1}"; // 替换为实际的命令
try {
// 构建请求体
String postData = String.format("{\"device\":\"%s\",\"order\":%s}", device, order);
// 发送 POST 请求
HttpResponse<String> response = Unirest.post(url)
.header("Content-Type", "application/json")
.body(postData)
.asString();
// 输出响应
System.out.println(response.getBody());
} catch (UnirestException e) {
e.printStackTrace();
}
}
}
说明:{AppID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档。
2. 智能语音壁挂音箱|款式1
远程语音播报、语音提醒、语音通知、语音警报;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒等;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
支持远程音量、音色、语调、语速设置;
支持多音字、支持数字(数值、金额、手机号等)读法;
内置铃声、提示音、警示音各5种;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;
一体化设计,安装简单;
使用Java语言调用HTTP接口控制智能语音壁挂音箱|款式1的代码
以设备控制(向设备下发命令)为例
全部接口文档复制
// 核心请求地址: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命令
/*首先,确保在你的项目中添加了 unirest 的 Maven 依赖。如果你使用的是 Maven,可以在 pom.xml 中添加以下依赖:
<dependency>
<groupId>com.konghq</groupId>
<artifactId>unirest-java</artifactId>
<version>3.13.10</version>
</dependency>
*/
import com.konghq.unirest.http.HttpResponse;
import com.konghq.unirest.http.Unirest;
import com.konghq.unirest.http.exceptions.UnirestException;
import org.apache.commons.codec.digest.DigestUtils;
public class Main {
public static void main(String[] args) {
// 定义变量
String AppID = "开发者ID"; // 替换为实际的 AppID
String AppSecret = "开发者密码"; // 替换为实际的 AppSecret
long ts = System.currentTimeMillis() / 1000; // 获取当前时间戳(秒)
// 计算签名 md5(md5(开发者密码)拼接上面的ts参数)
String sign = DigestUtils.md5Hex(DigestUtils.md5Hex(AppSecret) + ts);
// 构建 URL
String url = String.format("https://api.yoyoiot.cn/%s/device/control/?sign=%s&ts=%d", AppID, sign, ts);
// 请求体数据
String device = "1878"; // 替换为实际的设备ID;可传多个[用,间隔]
String order = "{\"power1\":1}"; // 替换为实际的命令
try {
// 构建请求体
String postData = String.format("{\"device\":\"%s\",\"order\":%s}", device, order);
// 发送 POST 请求
HttpResponse<String> response = Unirest.post(url)
.header("Content-Type", "application/json")
.body(postData)
.asString();
// 输出响应
System.out.println(response.getBody());
} catch (UnirestException e) {
e.printStackTrace();
}
}
}
说明:{AppID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档。
3. 智能语音吸顶音箱
远程语音播报、语音提醒、语音通知、语音警报;
广泛应用于各种线下服务的订单提醒、线下流程的语音提醒等;
无需上传录音、无需后台设置;
直接通过HTTP接口推送文本,即可实时远程语音播报;
真人发声、语调自然柔和,支持男、女音色;
支持远程音量、音色、语调、语速设置;
支持多音字、支持数字(数值、金额、手机号等)读法;
内置铃声、提示音、警示音各5种;
可无缝接入各种OA、ERP、SaaS软件和低代码平台中;
一体化设计,安装简单;
使用Java语言调用HTTP接口控制智能语音吸顶音箱的代码
以设备控制(向设备下发命令)为例
全部接口文档复制
// 核心请求地址: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命令
/*首先,确保在你的项目中添加了 unirest 的 Maven 依赖。如果你使用的是 Maven,可以在 pom.xml 中添加以下依赖:
<dependency>
<groupId>com.konghq</groupId>
<artifactId>unirest-java</artifactId>
<version>3.13.10</version>
</dependency>
*/
import com.konghq.unirest.http.HttpResponse;
import com.konghq.unirest.http.Unirest;
import com.konghq.unirest.http.exceptions.UnirestException;
import org.apache.commons.codec.digest.DigestUtils;
public class Main {
public static void main(String[] args) {
// 定义变量
String AppID = "开发者ID"; // 替换为实际的 AppID
String AppSecret = "开发者密码"; // 替换为实际的 AppSecret
long ts = System.currentTimeMillis() / 1000; // 获取当前时间戳(秒)
// 计算签名 md5(md5(开发者密码)拼接上面的ts参数)
String sign = DigestUtils.md5Hex(DigestUtils.md5Hex(AppSecret) + ts);
// 构建 URL
String url = String.format("https://api.yoyoiot.cn/%s/device/control/?sign=%s&ts=%d", AppID, sign, ts);
// 请求体数据
String device = "1878"; // 替换为实际的设备ID;可传多个[用,间隔]
String order = "{\"power1\":1}"; // 替换为实际的命令
try {
// 构建请求体
String postData = String.format("{\"device\":\"%s\",\"order\":%s}", device, order);
// 发送 POST 请求
HttpResponse<String> response = Unirest.post(url)
.header("Content-Type", "application/json")
.body(postData)
.asString();
// 输出响应
System.out.println(response.getBody());
} catch (UnirestException e) {
e.printStackTrace();
}
}
}
说明:{AppID}为您的应用ID(由平台生成),免费注册登录后,可在控制台查看;sign和ts的取值,请参考文档。
产品参数对比
产品 / 版本 参数 | 智能语音音柱|10W | 智能语音壁挂音箱|款式1 | 智能语音吸顶音箱 |
---|---|---|---|
白色 | 白色 | 白色 | |
外壳材质 | 铝合金 | 塑料 | |
产品尺寸 | 104mm宽84mm x高260mm | 宽:175mm;长:175mm;厚:90mm | |
产品净重 | 1.04KG | 528g | |
产品颜色 | 白色 | 白色 | |
工作电压 | DC 12V2A(直流) | DC 12V2A(直流) | |
待机功耗 | 0.4(静音) - 3.7(最大音量播放)W | 0.4(静音) - 3.7(最大音量播放)W | |
发声单元 | 2寸高音 + 4寸中低音 | ||
灵敏度 | 89db | ||
频率响应 | 0.1-16K | ||
无线连接 | WiFi IEEE 802.11 b / g / n 2.4GHz | WiFi IEEE 802.11 b / g / n 2.4GHz | |
产品外壳 | 铝合金,分隔式绝缘隔断,防止漏电风险,符合安规标准 | 防火V0级PC,耐高温,符合安规标准 | |
包装清单 | 智能音响*1 、 支架*3 、 螺丝*3 、 12V2A电源*1 | 智能语音音响*1 、12V2A电源 |