表达js表格数据

时间:2014-07-17 10:03:21

标签: javascript node.js express connect

有人可以告诉我推荐的(最新的)方法,以快递方式获取POST表单数据。

有很多教程/帖子等谈论bodyParser,但这不再与Express捆绑在一起,其他博客等推荐直接使用urlencoded,但现在也无法使用。

试图找到有关这些框架或技术的准确信息正在努力。

BTW我感兴趣的是非常简单的小表格数据

5 个答案:

答案 0 :(得分:54)

您应该通过body-parser安装npm-install。现在它是一个单独的中间件。

之后在app.js中添加以下行

var bodyParser = require('body-parser');
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
// in latest body-parser use like below.
app.use(bodyParser.urlencoded({ extended: true }));

它将post请求解析为object。您将在req.body

中获取变量

post请求处理程序中。

app.post('/post',function(request,response){
   console.log(request.body) //you will get your data in this as object.
})

编辑1

上面的答案是针对特别提出的问题,OP正在寻找不再属于bodyParser的{​​{1}}(已弃用)。

由于问题的标题非常通用且答案并未包含express的所有方面,因此我会将@ StLia的答案作为编辑。

Body-Parser Readme

  

由于它们复杂且通常较大,因此不能处理多部分主体。对于多部分机构,您可能对以下模块感兴趣:

答案 1 :(得分:13)

来自body-parser的自述文件:

  

由于它们复杂而且不能处理多部分主体   通常是大自然。

以上内容适用于x-www-form-urlencodedjson,但不适用于任何multipartform-data也是multipart,标题为multipart/form-data

如果是form-data,您最好的解决方案是使用express-formidable

答案 2 :(得分:13)

您可以使用 express-formidable 模块。 通过以下命令安装'express-formidable' npm install express-formidable

简单的例子如下

const express = require('express');
const formidable = require('express-formidable');

var app = express();

app.use(formidable());

app.post('/upload', (req, res) => {
  //req.fields contains non-file fields 
  //req.files contains files 
  res.send(JSON.stringify(req.fields));
});

Click here for further description

答案 3 :(得分:3)

我注意到@HubballiHuli 的回答是使用一个名为 express-formidable 的包。 您不需要使用这个不必要的包,它提供了一个(小)代码文件。 相反,您可以自己完成(现在删除依赖项)。

这是强大的中间件文件:

'use strict';

const formidable = require('formidable');

function parse(opts, events) {
  return (req, res, next) => {
    if (req.express_formidable && req.express_formidable.parsed) {
      next();
      return;
    }

    const form = new formidable.IncomingForm();
    Object.assign(form, opts);

    let manageOnError = false;
    if (events) {
      events.forEach((e) => {
        manageOnError = manageOnError || e.event === 'error';
        form.on(e.event, (...parameters) => { e.action(req, res, next, ...parameters); });
      });
    }

    if (!manageOnError) {
      form.on('error', (err) => {
        next(err);
      });
    }

    form.parse(req, (err, fields, files) => {
      if (err) {
        next(err);
        return;
      }

      Object.assign(req, { fields, files, express_formidable: { parsed: true } });
      next();
    });
  };
}

module.exports = parse;
exports.parse = parse;

现在介绍如何使用它:

const express = require('express');
const formidableMiddleware = require('./formidableMiddleware.js');

var app = express();

app.use(formidableMiddleware());

app.post('/upload', (req, res) => {
  //req.fields contains non-file fields 
  //req.files contains files 
  res.send(JSON.stringify(req.fields));
});

我前段时间写了一篇关于不必要的包以及为什么不使用它们的文章: https://medium.com/@alexjamesdunlop/unnecessary-packages-b3623219d86

答案 4 :(得分:1)

除了formidable的解决方案之外,自2019年以来,我在最近的项目中还使用了另一个模块。模块express-form-data可以在服务器文件中轻松声明,例如:

const express = require('express');
const formData = require('express-form-data');

app.use(formData.parse());

app.post('/image-upload', (req, res) => {
  console.log(req.files);
})

...

例如,如果图像上传,req.files将提供处理文件所需的所有相关数据,例如路径,大小,文件名等。