我正在尝试运行一个简单的Google Cloud / Speech应用程序,将我的Mic音频转换为文本。我的index.js.below
var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
const record = require('node-record-lpcm16');
// Imports the Google Cloud client library
const speech = require('@google-cloud/speech');
// Creates a client
const client = new speech.SpeechClient();
/**
* TODO(developer): Uncomment the following lines before running the sample.
*/
const encoding = 'LINEAR16';
const sampleRateHertz = 16000;
const languageCode = 'en-US';
const request = {
config: {
encoding: encoding,
sampleRateHertz: sampleRateHertz,
languageCode: languageCode,
},
interimResults: false, // If you want interim results, set this to true
};
// Create a recognize stream
const recognizeStream = client
.streamingRecognize(request)
.on('error', console.error)
.on('data', data =>
process.stdout.write(
data.results[0] && data.results[0].alternatives[0]
? `Transcription: ${data.results[0].alternatives[0].transcript}\n`
: `\n\nReached transcription time limit, press Ctrl+C\n`
)
);
// Start recording and send the microphone input to the Speech API
record
.start({
sampleRateHertz: sampleRateHertz,
threshold: 0,
// Other options, see https://www.npmjs.com/package/node-record-lpcm16#options
verbose: false,
recordProgram: 'rec', // Try also "arecord" or "sox"
silence: '10.0',
})
.on('error', console.error)
.pipe(recognizeStream);
console.log('Listening, press Ctrl+C to stop.');
app.get('/', function(req, res){
res.sendFile(__dirname + '/index.html');
});
io.on('connection', function(socket){
console.log('a user connected');
});
http.listen(3000, function(){
console.log('listening on *:3000');
});
如果我在本地运行上面的代码,它可以很好地工作。如果我删除所有Google语音代码,服务器运行正常。但是当使用上面的(Same as the Docs)时Heroku旋转起来然后抛出一个错误。
2019-02-25T09:07:38.000000+00:00 app[api]: Build succeeded
2019-02-25T09:07:39.926417+00:00 app[web.1]:
2019-02-25T09:07:39.926435+00:00 app[web.1]: > [email protected] start /app
2019-02-25T09:07:39.926437+00:00 app[web.1]: > node index.js
2019-02-25T09:07:39.926439+00:00 app[web.1]:
2019-02-25T09:07:40.617413+00:00 app[web.1]: Listening, press Ctrl+C to stop.
2019-02-25T09:07:40.626395+00:00 app[web.1]: events.js:174
2019-02-25T09:07:40.626399+00:00 app[web.1]: throw er; // Unhandled 'error' event
2019-02-25T09:07:40.626401+00:00 app[web.1]: ^
2019-02-25T09:07:40.626403+00:00 app[web.1]:
2019-02-25T09:07:40.626405+00:00 app[web.1]: Error: spawn rec ENOENT
2019-02-25T09:07:40.626407+00:00 app[web.1]: at Process.ChildProcess._handle.onexit (internal/child_process.js:240:19)
2019-02-25T09:07:40.626410+00:00 app[web.1]: at onErrorNT (internal/child_process.js:415:16)
2019-02-25T09:07:40.626412+00:00 app[web.1]: at process._tickCallback (internal/process/next_tick.js:63:19)
2019-02-25T09:07:40.626414+00:00 app[web.1]: at Function.Module.runMain (internal/modules/cjs/loader.js:745:11)
2019-02-25T09:07:40.626416+00:00 app[web.1]: at startup (internal/bootstrap/node.js:283:19)
2019-02-25T09:07:40.626417+00:00 app[web.1]: at bootstrapNodeJSCore (internal/bootstrap/node.js:743:3)
2019-02-25T09:07:40.626419+00:00 app[web.1]: Emitted 'error' event at:
2019-02-25T09:07:40.626421+00:00 app[web.1]: at Process.ChildProcess._handle.onexit (internal/child_process.js:246:12)
2019-02-25T09:07:40.626423+00:00 app[web.1]: at onErrorNT (internal/child_process.js:415:16)
2019-02-25T09:07:40.626425+00:00 app[web.1]: [... lines matching original stack trace ...]
2019-02-25T09:07:40.626427+00:00 app[web.1]: at bootstrapNodeJSCore (internal/bootstrap/node.js:743:3)
2019-02-25T09:07:40.636937+00:00 app[web.1]: npm ERR! code ELIFECYCLE
我将所有Google Cloud凭据设置为Heroku中的环境变量,它们似乎工作正常。
任何帮助深表感谢。
干杯