讯飞socket版tts之nodejs应用

Posted meteorcn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了讯飞socket版tts之nodejs应用相关的知识,希望对你有一定的参考价值。

本文使用的npm核心库: https://www.npmjs.com/package/xf-tts-socket

 

最近在看文本转语音的服务,经过多次对比后,发现综合来看还是讯飞的体验最好。其他家转换出来的语音,都过于生硬,一听就是机器人。只有讯飞家的比较接近正常人的发音特点。

在线体验科大讯飞文本转语音服务: https://www.xfyun.cn/services/online_tts

 

下一步就是尝试整合到自己的项目中去了。查看官网说明,发现新版本的tts API有以下特点:

1. 只支持websocket,与常规意义上的API使用方式差异较大

2. 鉴权方面需要多次复杂的编码转换

3. 只支持pcm格式的语音返回,不支持mp3, wav格式等

4. 对nodejs的异步,回调没有支持

 

上述几个特点,导致使用它比较不容易。最终决定自己多花一些时间,写一个通用支持类库。这个类库的目标就是简化调用,只提供必须的信息,一个函数调用即可。目前这个库已经上传npm,希望可以给其他人使用时提供进一步的便利。

 

这个库的核心功能:

1. 符合常规nodejs调用方式,不必关心websocket部分

2. 支持async-await和回调语法

3. 支持多语音格式,pcm, mp3, wav等

 

 

npm包地址:https://www.npmjs.com/package/xf-tts-socket

安装方式:npm install xf-tts-socket --save

 

async-await使用方式(默认发音人设置)

const XunfeiTTS = require(‘xf-tts-socket‘);
const { promisify } = require(‘util‘);
const getXunfeiTTSAsync = promisify(XunfeiTTS);
 
const test = async () => {
  const auth = {
    app_id: ‘xxxxxx‘,
    app_skey: ‘xxxxxxxxxxx‘,
    app_akey: ‘xxxxxxxxxxx‘,
  };
  const business = {};
  const text = ‘如果握手失败,则根据不同错误类型返回不同HTTP Code状态码‘;
  const file = ‘test.mp3‘;
 
  const ret = await getXunfeiTTSAsync(auth, business, text, file);
  console.log(‘ret‘, ret);
};
 
test();

 

async-await使用方式(自定义发音人设置)

const XunfeiTTS = require(‘xf-tts-socket‘);
const { promisify } = require(‘util‘);
const getXunfeiTTSAsync = promisify(XunfeiTTS);
 
const test = async () => {
  const auth = {
    app_id: ‘xxxxxx‘,
    app_skey: ‘xxxxxxxxxxx‘,
    app_akey: ‘xxxxxxxxxxx‘,
  };
  const business = {
    aue: ‘raw‘,
    auf: ‘audio/L16;rate=16000‘,
    vcn: ‘aisbabyxu‘,
    tte: ‘UTF8‘,
    speed: 50
  };
  const text = ‘如果握手失败,则根据不同错误类型返回不同HTTP Code状态码‘;
  const file = ‘test.mp3‘;
 
  const ret = await getXunfeiTTSAsync(auth, business, text, file);
  console.log(‘ret‘, ret);
};
 
test();

 

callback使用方式(默认发音人设置)

const XunfeiTTS = require(‘xf-tts-socket‘);
 
const test = () => {
  const auth = {
    app_id: ‘xxxxxx‘,
    app_skey: ‘xxxxxxxxxxx‘,
    app_akey: ‘xxxxxxxxxxx‘,
  };
  const business = {};
  const text = ‘如果握手失败,则根据不同错误类型返回不同HTTP Code状态码‘;
  const file = ‘test.mp3‘;
  XunfeiTTS(auth, business, text, file, (err, ret) => {
    console.log(‘ret‘, ret);
  });
};
 
test();

 

以上是关于讯飞socket版tts之nodejs应用的主要内容,如果未能解决你的问题,请参考以下文章

吾剑未尝不利,国内Azure平替,科大讯飞人工智能免费AI语音合成(TTS)服务Python3.10接入

Android TTS 文字转语音,中文需第三方插件

Android TTS 文字转语音,中文需第三方插件

求《中科大讯飞Interphonic 5.0语音合成系统》的下载地址或者发我一份!!

语音云的讯飞语音开放介绍

php调用讯飞语音合成