【问题标题】:POST request empty (body-parser extended: true) - still not working?POST 请求为空(body-parser 扩展:true) - 仍然无法正常工作?
【发布时间】:2019-04-26 15:55:24
【问题描述】:

我被难住了。 我正在对记录请求正文的后端进行简单的 fetch(),即 console.log(req.body.form_data)

问题:返回 {} 空 json 对象。

尝试:我已经安装了body-parser,即

 app.use(express.urlencoded({ extended: true }));
   // body parser - parse json in body.requests
    app.use(bodyParser.json());   // to support JSON-encoded bodies
    app.use(bodyParser.urlencoded({
      extended: true  }));        // to support URL-encoded bodies

怎么了?

app.js

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');

var bodyParser = require('body-parser');

var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');


app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
// body parser - parse json in body.requests
app.use(bodyParser.json());   // to support JSON-encoded bodies
app.use(bodyParser.urlencoded({
  extended: true              // to support URL-encoded bodies
}));

app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', indexRouter);
app.use('/users', usersRouter);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  next(createError(404));
});

// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

index.js

var express = require('express');
var router = express.Router();

let users = [];

/* GET home page. */
router.get('/', function(req, res, next) {
  res.render('index', { title: 'Express' });
});

router.post('/', function(req, res, next) {
  if(req.body.form_data) {
    console.log(req.body.form_data)
    // res.json(users);
  }
  console.log(req.body)

  res.render('index', { title: 'TO DO APP' });
});
module.exports = router;

myscript.js

document.getElementById("listForm").addEventListener('submit', function(e) {
    e.preventDefault();

    const fname = document.getElementById("fname").value;
    const list_name = document.getElementById("list-name").value;
    const list_date = document.getElementById("list-date").value;

     var form_data = { 
         fname: fname,
         list_name: list_name,
         list_date: list_date
    };
    console.log(form_data );


    // AJAX fetch()
    fetch('/', {
        method: 'POST',
        headers: new Headers(),
        body: form_data
    }).then(function(response) {
        console.log("response..");
        return response.json();
    }).then(function(user_json) {
        console.log(user_json);
    });
});

index.pug

extends layout

block content
  h1= title
  p First, create your list

  form#listForm(method="POST" action="/")
    input(type='text' id="fname" name='fname' autofocus placeholder="your name")
    input(type='text' id="list-name" name='list-name' autofocus placeholder="name your list")
    input(type='date' id="list-date" name='list-date' autofocus placeholder="today's date") 
    button(type='submit') Create List

【问题讨论】:

  • 尝试使用这个:var router = express(); 我不知道这是否会有所不同,但请尝试。强烈感觉问题出在index.js。但是请检查您的控制台,看看您是否真的在进行任何 AJAX 调用。
  • 你的意思是:var router = express.Router();到 var router = express(); ..没有改变任何东西
  • 你在传递标题content-type: application/json??没有它,body 解析器将无法知道您已经传递了 json 并且它需要解析它。
  • 不,我正在使用 fetch() 正文中编写的 headers() ......你是什么意思?示例
  • inside index.js 这行的结果是什么:console.log(req.body) 你能添加你的日志结果吗?

标签: javascript node.js json api body-parser


【解决方案1】:

我想您需要将 content-type 标头与您当前未发送的请求一起传递。此外,您还需要使用 JSON.stringify 将其转换为 JSON 字符串,如下所示。

let headers = new Headers();
headers.append('content-type','application/json');
fetch('/', {
    method: 'POST',
    headers: headers,
    body: JSON.stringify(form_data)
}).then(function (response) {
    console.log("response..");
    return response.json();
}).then(function (user_json) {
    console.log(user_json);
});

【讨论】:

  • 好吧原来console.log(req.body)正在打印请求但不是console.log(req.body.form_data)...有什么想法吗??
  • 因为没有将form_data作为字段传递,所以字段是fname、list_name、list_date。它应该将req.body.form_data 显示为undefined
  • 哦。在我的后端,我需要检查不同的发布请求,即 if(form_data) if(form2_data) 等。发送我的 json 对象以使其像这样工作的正确方法是什么?
  • 你会怎么做?发送一个以 json 对象为元素的数组是我能想到的唯一方法
  • 你为什么需要那样做?这不是正确的方法吗?您应该访问像 req.body.firstName 这样的密钥和类似的东西。我不认为你试图做的是一个好主意。
猜你喜欢
  • 2019-02-25
  • 2020-07-20
  • 2018-01-28
  • 1970-01-01
  • 1970-01-01
  • 2018-10-16
  • 1970-01-01
  • 1970-01-01
  • 2021-04-10
相关资源
最近更新 更多