node.js 上传下载pdf文件
node.js upload and download pdf file
框架: node.js/express.js/busboy/gridfs-stream(mongodb)
我正在使用 busboy 上传文件,然后使用 gridfs-stream 将文件存储在 mongodb gridfs 中。
req.pipe(req.busboy);
req.busboy.on('file', function (bus_fieldname, bus_file, bus_filename) {
var writestream = gfs.createWriteStream({
filename: bus_filename,
});
bus_file.pipe(writestream);
writestream.on('close', function (file) {
res.redirect('/xxxxx/');
});
});
下载很简单:使用gridfs-stream的createReadStream我从mongodb读取内容,然后使用下面的代码发送到浏览器。
gfs.findOne({_id: attachmentid}, function (err, file) {
if (err || !file){
res.send(404);
}else{
var fileName = file.filename;
var readstream = gfs.createReadStream({_id: attachmentid});
var buffer = "";
readstream.on("data", function (chunk) {
buffer += chunk;
});
// dump contents to buffer
readstream.on("end", function () {
res.set("Content-Disposition","attachment; filename=" + fileName);
res.send(buffer);
});
}
问题:当我上传一个 90kb 的 pdf 文件时,它上传正常。我看到 mongodb 中的尺寸是正确的。但是当我下载时,下载文件的文件大小约为165kb。存在不匹配。文本文件不会发生这种情况。当然跟数据类型有关。
有人可以帮忙吗?
将 gfs 读取流直接通过管道传输到响应。这对我有用
res.set("Content-Disposition","attachment; filename=" + fileName);
var readstream = gfs.createReadStream({_id: attachmentid});
readstream.pipe(res);
正如 Sasikanth 所说,您可以通过管道解决问题,这是最好的方法。
但是如果您想知道您当前的方法有什么问题,那么我建议您阅读 Buffer documentation.You are naming your variable as buffer
but assigning string.
然后在您的 data
回调中,您将使用 Buffer 添加字符串。当您这样做时,chunk
缓冲区将使用它的 toString()
方法转换为字符串。所以你的二进制数据被转换为 utf8 编码的字符串,这里出错了。由于 utf8 是多字节编码,因此输出大小变大(我不知道这种转换的确切机制)。
所以正确的做法是将其保存在缓冲区中:
var buffers = [];
readstream.on("data", function (chunk) {
buffers.push(chunk)
});
readstream.on("end", function () {
res.set("Content-Disposition","attachment; filename=" + fileName);
res.send(Buffer.concat(buffers));
});
框架: node.js/express.js/busboy/gridfs-stream(mongodb)
我正在使用 busboy 上传文件,然后使用 gridfs-stream 将文件存储在 mongodb gridfs 中。
req.pipe(req.busboy);
req.busboy.on('file', function (bus_fieldname, bus_file, bus_filename) {
var writestream = gfs.createWriteStream({
filename: bus_filename,
});
bus_file.pipe(writestream);
writestream.on('close', function (file) {
res.redirect('/xxxxx/');
});
});
下载很简单:使用gridfs-stream的createReadStream我从mongodb读取内容,然后使用下面的代码发送到浏览器。
gfs.findOne({_id: attachmentid}, function (err, file) {
if (err || !file){
res.send(404);
}else{
var fileName = file.filename;
var readstream = gfs.createReadStream({_id: attachmentid});
var buffer = "";
readstream.on("data", function (chunk) {
buffer += chunk;
});
// dump contents to buffer
readstream.on("end", function () {
res.set("Content-Disposition","attachment; filename=" + fileName);
res.send(buffer);
});
}
问题:当我上传一个 90kb 的 pdf 文件时,它上传正常。我看到 mongodb 中的尺寸是正确的。但是当我下载时,下载文件的文件大小约为165kb。存在不匹配。文本文件不会发生这种情况。当然跟数据类型有关。
有人可以帮忙吗?
将 gfs 读取流直接通过管道传输到响应。这对我有用
res.set("Content-Disposition","attachment; filename=" + fileName);
var readstream = gfs.createReadStream({_id: attachmentid});
readstream.pipe(res);
正如 Sasikanth 所说,您可以通过管道解决问题,这是最好的方法。
但是如果您想知道您当前的方法有什么问题,那么我建议您阅读 Buffer documentation.You are naming your variable as buffer
but assigning string.
然后在您的 data
回调中,您将使用 Buffer 添加字符串。当您这样做时,chunk
缓冲区将使用它的 toString()
方法转换为字符串。所以你的二进制数据被转换为 utf8 编码的字符串,这里出错了。由于 utf8 是多字节编码,因此输出大小变大(我不知道这种转换的确切机制)。
所以正确的做法是将其保存在缓冲区中:
var buffers = [];
readstream.on("data", function (chunk) {
buffers.push(chunk)
});
readstream.on("end", function () {
res.set("Content-Disposition","attachment; filename=" + fileName);
res.send(Buffer.concat(buffers));
});