如何禁用 restify.plugin.bodyParser 文件上传
How to disable restify.plugin.bodyParser for file uploads
这个问题和How to disable Express BodyParser for file uploads (Node.js).非常相似,但是他们提供的答案是针对Express的,我已经尝试了Restify 7的解决方案,但似乎没有用。
我正在使用 Node.js + Restify 构建 Restfull 应用程序。我正在使用 BodyParser 来解析 post 参数。但是,我想访问多部分表单数据 POSTS。
我使用 multer、multer-s3 和 aws-sdk,我想访问数据以将它们发送到 digitalocean sapce。但是所有文件上传都被restify.plugin.bodyParser.
自动解析
有没有办法让我禁用多部分表单数据 post 的 BodyParser,而不禁用其他所有内容?
这是一个示例代码:
const restify = require('restify');
const errors = require('restify-errors');
const aws = require('aws-sdk');
const multer = require('multer');
const multerS3 = require('multer-s3');
const server = restify.createServer();
server.use(restify.plugins.acceptParser(server.acceptable));
server.use(restify.plugins.bodyParser());
// Set S3 endpoint to DigitalOcean Spaces
const spacesEndpoint = new aws.Endpoint('nyc3.digitaloceanspaces.com');
const s3 = new aws.S3({
endpoint: spacesEndpoint
});
const upload = multer({
storage: multerS3({
s3: s3,
bucket: 'space_name',
acl: 'public-read',
key: function (request, file, cb) {
console.log(file);
cb(null,new Date().toISOString());
}
})
}).single('logo');
server.post('/upload', async (req, res, next) => {
upload(req, res, async (error) => {
if (error) {
console.log(error);
return next(new errors.InvalidContentError(error));
}
console.log('File uploaded successfully.');
res.send(200);
next();
});
});
我刚刚将 server.use(restify.plugins.bodyParser());
更改为 server.use(restify.plugins.jsonBodyParser());
,一切正常
这个问题和How to disable Express BodyParser for file uploads (Node.js).非常相似,但是他们提供的答案是针对Express的,我已经尝试了Restify 7的解决方案,但似乎没有用。
我正在使用 Node.js + Restify 构建 Restfull 应用程序。我正在使用 BodyParser 来解析 post 参数。但是,我想访问多部分表单数据 POSTS。
我使用 multer、multer-s3 和 aws-sdk,我想访问数据以将它们发送到 digitalocean sapce。但是所有文件上传都被restify.plugin.bodyParser.
自动解析有没有办法让我禁用多部分表单数据 post 的 BodyParser,而不禁用其他所有内容?
这是一个示例代码:
const restify = require('restify');
const errors = require('restify-errors');
const aws = require('aws-sdk');
const multer = require('multer');
const multerS3 = require('multer-s3');
const server = restify.createServer();
server.use(restify.plugins.acceptParser(server.acceptable));
server.use(restify.plugins.bodyParser());
// Set S3 endpoint to DigitalOcean Spaces
const spacesEndpoint = new aws.Endpoint('nyc3.digitaloceanspaces.com');
const s3 = new aws.S3({
endpoint: spacesEndpoint
});
const upload = multer({
storage: multerS3({
s3: s3,
bucket: 'space_name',
acl: 'public-read',
key: function (request, file, cb) {
console.log(file);
cb(null,new Date().toISOString());
}
})
}).single('logo');
server.post('/upload', async (req, res, next) => {
upload(req, res, async (error) => {
if (error) {
console.log(error);
return next(new errors.InvalidContentError(error));
}
console.log('File uploaded successfully.');
res.send(200);
next();
});
});
我刚刚将 server.use(restify.plugins.bodyParser());
更改为 server.use(restify.plugins.jsonBodyParser());
,一切正常