华军软件园:为用户提供海量热门软件、游戏等手机资源下载服务!

装机必备热门标签玩游戏装软件BT游戏H5游戏看教程专题游戏盒子手机版

华军软件园

所在位置:首页 > 资讯教程 > 软件教程 >  > 详情

如何使用微信小程序实现语音识别?

文章来源:网络作者:基神发布时间:2026-05-30 18:16:06

GM盒子
GM盒子(高返利版)
GM手游福利平台,免费送首充,上线送VIP,免费领元宝和代金券。
Ready

  今天小编给大家讲解如何使用微信小程序实现语音识别?有需要或者有兴趣的朋友们可以看一看下文,相信对大家会有所帮助的。

  1、概述

  通过微信小程序wx.startRecord()和wx.stopRecord()接口录音并上传silk录音文件至服务器,通过ffmpeg将silk录音文件转成wav录音文件,再通过百度语音识别 REST API 获取语音识别后的结果。

  2、代码实现

  录音和语音文件上传

  //index.js

  //开始录音。当主动调用wx.stopRecord,

  //或者录音超过1分钟时自动结束录音,返回录音文件的临时文件路径。

  //当用户离开小程序时,此接口无法调用。

  wx.startRecord({

  success: function (res) {

  console.log(\'录音成功\' + JSON.stringify(res));that.setData({

  voiceButtonName: \'语音识别\',

  voicePlayButtonName: \'开始播放\',

  tempFilePath: res.tempFilePath

  })

  //上传语音文件至服务器

  wx.uploadFile({

  url: \'https://你的域名/upload\',

  filePath: res.tempFilePath,

  name: \'file\',

  // header: {}, // 设置请求的 header

  formData: {

  \'msg\': \'voice\'

  }, // HTTP 请求中其他额外的 form data

  success: function (res) {

  // success

  console.log(\'begin\');

  console.log(res.data);

  var json = JSON.parse(res.data);

  console.log(json.msg);

  var jsonMsg = JSON.parse(json.msg);

  console.log(jsonMsg.result);

  wx.navigateTo({

  url: \'../voicePage/voicePage?voiceData=\' + jsonMsg.result.join(\'\')})

  },

  fail: function (err) {

  // fail

  console.log(err);

  },

  complete: function () {

  // complete

  }

  })

  },

  fail: function (res) {

  //录音失败

  that.setData({

  voiceButtonName: \'语音识别\'

  })

  console.log(\'录音失败\' + JSON.stringify(res));}

  })

  setTimeout(function () {

  //结束录音

  wx.stopRecord()

  }, 60000)

  node.js服务端接收语音文件代码

  //upload.js

  //使用koa-multer这个组件

  var multer = require(\'koa-multer\');

  var router = require(\'koa-router\')();

  var path = require(\'path\');

  //存储文件至path.resolve(\'./voice-file\')路径var upload = multer({ dest: path.resolve(\'./voice-file\')});router.post(\'/\', upload.single(\'file\'), async function (ctx, next) {//这是就文件的具体信息

  console.log(ctx.req.file);

  });

  silk文件转wav文件

  我使用的是silk-v3-decoder将silk文件转wav文件

  silk-v3-decoder 使用方法

  //upload.js

  var exec = require(\'child_process\').exec;

  function silkToWav(file){

  return new Promise(function (resolve, reject) {

  exec(\'sh converter.sh \' + file + \' wav\', function(err,stdout,stderr){

  if(err) {

  resolve({

  result : false,

  msg : stderr

  });

  } else {

  //var data = JSON.parse(stdout);

  console.log(stdout);

  console.log(stderr);

  //console.log(err);

  resolve({

  result : true,

  msg : \'\'

  });

  }

  });

  });

  }

  百度语音识别 REST API识别wav文件

  1、通过API Key和Secret Key获取的access_token

  通过API Key和Secret Key获取的access_token文档

  //speech.js

  speech.getAccessToken = function(){

  return new Promise(function (resolve, reject) {

  request({

  url: \'https://openapi.baidu.com/oauth/2.0/token?grant_type=client_credentials&client_id=(你自己的API key)&client_secret=(你自己的Secret Key)\',

  method: \'get\',

  headers: {

  \'content-type\': \'application/json\'

  }

  }, function (error, response, data) {

  if (error){

  resolve({

  \'result\' : false,

  \'msg\' : \'出现错误: \' + JSON.stringify(error)

  });

  }else {

  resolve({

  \'result\' : true,

  \'msg\' : data

  });

  }

  });

  });

  }

  2、通过token 调用百度语音识别 REST API识别接口

  //speech.js

  speech.recognize = function(base64String, size){

  return new Promise(function (resolve, reject) {

  request({

  url: \'//vop.baidu.com/server_api\',

  method: \'post\',

  headers: {

  \'content-type\': \'application/json\'

  },

  // len + speech方式

  body: JSON.stringify({

  "format":"wav",

  "rate":16000,

  "channel":1,

  "token":\'(你的token)\',

  "cuid":"9e:eb:e8:d4:67:00",

  "len":size,

  "speech":base64String

  })

  //url + callback方式

  //body: JSON.stringify({

  // "format":"wav",

  // "rate":16000,

  // "channel":1,

  // "token":\'(你的token)\',

  // "cuid":\'9eebe8d46700\',

  // "url":\'//ihealth-wx.s1.natapp.cc/download?name=123.wav\',

  // "callback":\'//ihealth-wx.s1.natapp.cc/callback\'

  //})

  }, function (error, response, data) {

  if (error){

  resolve({

  result : false,

  msg : \'出现错误: \' + JSON.stringify(error)

  });

  }else {

  resolve({

  result : true,

  msg : data

  });

  }

  });

  });

  }

  3、语音识别优化

  通过上述操作后,发现识别的内容和实际内容差别很大

  百度语音识别 REST API文档

  查看文档可知:采样率:8000/16000 仅支持单通道

  在ffmpeg里对应的设置方式分别是:

  -ar rate 设置采样率

  -ac channels 设置声道数

  修改converter.sh文件,修改为下图所示

  以上就是如何使用微信小程序实现语音识别的全部内容了,大家都学会了吗?

End
复制本文链接资讯文章为华军软件园所有,未经允许不得转载。
热门游戏MORE+
相关资讯MORE+
最新录入
热门资讯
新游新品榜
手机游戏
休闲益智
赛车竞速
棋牌桌游
角色扮演
动作射击
体育竞技
经营养成
策略塔防
冒险解谜
音乐游戏
手游辅助
H5游戏
BT游戏
手机软件
社交聊天
系统工具
时尚购物
旅游出行
影音播放
生活实用
办公学习
资讯阅读
拍摄美化
游戏辅助
健康医疗
地图导航
小说漫画
安全防护
育儿亲子
手游下载
梦想三国之勇往直前0....
炼仙传说0.1折
不可思议的刀剑与魔法...
逍遥浪人
奇幻梦旅人
玄影0.1折
点击冒险之旅(0.1折特...
天神赵子龙0.1折
九州异兽记0.1折
龙魂魔法0.1折
装机软件
爱奇艺电脑版
Steam下载管家 2026最...
360游戏大厅
GoLink加速器
3DM驱动大师
夸克
豆包电脑版
360C盘扩容大师
360录屏
360极速浏览器
精选专题
手机游戏专题
手机软件专题
电脑软件专题
电脑游戏专题
游戏排行榜
手游排行榜
软件排行榜
BT排行榜
电脑软件排行榜
电脑游戏排行榜