如何禁用 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());,一切正常