0

0

php怎么调用小米AI语音合成_php如何生成多音色自然语音播报内容

絕刀狂花

絕刀狂花

发布时间:2026-03-18 04:19:21

|

879人浏览过

|

来源于php中文网

原创

小米TTS SDK无原生PHP SDK,必须通过HTTPS API调用,需自行实现签名、token管理、文本分段(≤300字符)、音色切换(如zh-CN-xiaoyan)及WAV二进制流保存,常见错误为401(签名错)、400(参数异常)和500(token过期或音色不支持)。

php怎么调用小米ai语音合成_php如何生成多音色自然语音播报内容

小米TTS SDK的PHP接入必须走HTTP API,没有原生PHP SDK

小米AI语音合成(TTS)官方不提供PHP语言的SDK,所有调用都得通过其开放平台的https://ai.xiaomi.com/api/tts HTTP接口完成。你看到的“PHP SDK”基本是第三方封装或自行写的cURL封装,底层全是发POST请求+签名验证。

常见错误现象:401 Unauthorized(签名错)、400 Bad Request(text超长或缺参数)、500 Internal Error(token过期或音色不支持)。别在GitHub上找“xiaomi-tts-php”类库——多数没维护,且签名逻辑常写错。

  • 必须用client_idclient_secret申请access_token,有效期2小时,需自己缓存并刷新
  • 每次TTS请求的text参数不能超过300字符(含标点),超长需分段
  • 音色由voice参数控制,如zh-CN-xiaoyanzh-CN-lili,不是随便起名,得查官方文档的voice_list接口返回值
  • 返回是WAV二进制流,Content-Typeaudio/wav,别当成JSON解析

PHP生成多音色语音必须手动切换voice参数并重签请求

一个请求只能指定一个voice,想让“张三说一句、李四说一句”,就得发两次独立请求,分别带不同voice值,并各自生成对应音频文件。不存在“一次请求多个音色”的API能力。

使用场景:客服播报中区分角色(如“系统提示”用男声、“用户反馈”用女声),或教育App里不同角色配音。别指望靠后处理混音来“模拟多音色”——TTS服务本身不支持。

立即学习PHP免费学习笔记(深入)”;

蛙蛙写作
蛙蛙写作

超级AI智能写作助手

下载
  • 音色名大小写敏感,zh-cn-xiaoyan会失败,必须是zh-CN-xiaoyan
  • 部分音色仅限商用授权开通,测试时用zh-CN-xiaoyan最稳
  • 每次请求都要重新计算sign(HMAC-SHA256 + timestamp + nonce),不能复用旧签名
  • 若需拼接多段语音,用ffmpeg命令行合并:ffmpeg -i "concat:1.wav|2.wav" -acodec copy output.wav

curl_exec()返回空或乱码?检查AcceptContent-Type

PHP用curl_exec()调小米TTS接口时,返回空字符串或一堆不可读字符,90%是因为没设对请求头或没处理响应头。它不返回JSON,而是直接吐WAV二进制数据。

典型错误:用json_decode(curl_exec($ch))去解析,结果得到null;或者echo输出二进制流导致浏览器崩溃。

  • 请求头必须包含:Accept: audio/wavContent-Type: application/json
  • 务必加curl_setopt($ch, CURLOPT_BINARYTRANSFER, true),否则cURL可能截断二进制
  • 响应后立刻用file_put_contents('out.wav', $response)保存,别echoprint_r
  • 调试时先用curl_getinfo($ch, CURLINFO_HTTP_CODE)确认状态码是200

签名生成容易漏掉nonce或时间戳偏差

小米TTS签名要求sign = base64_encode(hmac_sha256(client_secret, client_id + timestamp + nonce + text)),其中timestamp是秒级时间戳,服务器时间与小米服务器偏差超过300秒就拒收。

最容易踩的坑:用microtime(true)生成毫秒戳、nonce重复使用、或拼接时没trim掉text首尾空格——这些都会导致401

  • nonce必须是16位随机字符串(推荐bin2hex(random_bytes(8))
  • timestamptime(),不是date('U')(虽然等价,但易误写成格式化字符串)
  • 签名原文拼接顺序严格:$client_id . $timestamp . $nonce . trim($text),少一个点都不行
  • 调试时把签名原文和生成的sign一起打日志,比对是否一致
实际跑通的关键,是把签名、token刷新、分段截文本、二进制保存这四步串成稳定流程。中间任何一环用错类型或漏掉trim,都会卡在401或400,而且错误信息极其模糊。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

458

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

84

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

255

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1154

2024.03.01

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

455

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

183

2023.10.30

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

17

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.4万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号