我刚开始在 ExpressJS Web 应用程序中使用 gcloud-node 并遇到了一个看似非常基本的问题,但我无法弄清楚。
我可以上传文件没有问题。我用:
fs.createReadStream(req.files.file.path)
.pipe(bucket.createWriteStream(name))
查看我的谷歌开发者控制台,我在我的存储桶中看到了该文件,例如名称:54314eddacd67fc858bf473f/543ba7bb387b56b908f2b1e4.jpg
当我尝试使用该名称下载时,即:
bucket.createReadStream(file.name)
.pipe(res)
.on('error', function(err) {
errorResponseHandler.handleError(res, err);
});
我收到此错误:
uncaughtException: Not Found
Error: Not Found
at Object.handleResp (/Users/ruairiobrien/Dev/testApp/node_modules/gcloud/lib/common/util.js:168:14)
at Bucket.makeReq_ (/Users/ruairiobrien/Dev/testApp/node_modules/gcloud/lib/storage/index.js:580:10)
at Request.Connection.req [as _callback] (/Users/ruairiobrien/Dev/testApp/node_modules/gcloud/lib/common/connection.js:251:16)
at Request.init.self.callback (/Users/ruairiobrien/Dev/testApp/node_modules/gcloud/node_modules/request/request.js:199:22)
at Request.emit (events.js:98:17)
at Request.onResponse (/Users/ruairiobrien/Dev/testApp/node_modules/gcloud/node_modules/request/request.js:1160:14)
at Request.emit (events.js:117:20)
at IncomingMessage.Request.onResponse.strings (/Users/ruairiobrien/Dev/testApp/node_modules/gcloud/node_modules/request/request.js:1111:12)
at IncomingMessage.emit (events.js:117:20)
at _stream_readable.js:929:16
我已经调试过了,我确定存储桶中存在具有正确名称的文件。
我真的很难过,所以任何帮助将不胜感激。
我也尝试将文件写入我的本地文件系统,而不是在响应中并得到相同的错误。
一个有效的临时(或永久)解决方法是:
bucket.getSignedUrl({
action: 'read',
expires: Math.round(Date.now() / 1000) + (60 * 60 * 24), // 1 day.
resource: file.name
}, function (err, url) {
res.redirect(url);
});
解决方法工作正常,但不能帮助我弄清楚为什么 createReadStream 失败,因为它表明文件名和存储桶是正确的。