Req.body пусто, экспресс js

Я часами пытался понять, почему req.body пуст. Я везде искал stackoverflow и пробовал все, но не повезло.

Я пробовал установить:

app.use(bodyParser.urlencoded({extended: false})); //false

но это ничего не изменило

Вот app.js

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

var index = require('./routes/index');
var ajax = require('./routes/ajax');


var app = express();

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

// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.urlencoded({extended: true}));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use(bodyParser.json());
app.disable('etag'); //disable cache control

app.use('/', index);
app.use('/ajax', ajax);


// catch 404 and forward to error handler
app.use(function (req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});

// 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;

Теперь посмотрим на ajax.js

var express = require('express');
var router = express.Router();
router.post('/1/kyc/form', function (req, res, next) {
    console.info(req.body) //prints {}
});

Это запрос, сделанный клиентом:

Req.body пусто, экспресс js

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
2
0
8 173
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Заголовок Content-Type вашего запроса недействителен:

Content-Type: application/json;

Завершающей точки с запятой там быть не должно. Так должно быть так:

Content-Type: application/json

FWIW, здесь используется не bodyParser.urlencoded; поскольку содержимое тела - это JSON, именно bodyParser.json обрабатывает тело запроса. Но это нормально, если оба этих парсеров тела будет активным.

РЕДАКТИРОВАТЬ: если то, что отправляет клиент, находится вне вашего контроля (или это слишком сложно исправить на стороне клиента), вы можете добавить дополнительное промежуточное ПО в Express, которое исправит недопустимый заголовок:

app.use(function(req, res, next) {
  if (req.headers['content-type'] === 'application/json;') {
    req.headers['content-type'] = 'application/json';
  }
  next();
});

Убедитесь, что вы сделали это перед в строке, которая загружает bodyParser.json.

Как мне сказать express js рассмотреть application / json; то же, что и application / json (я знаю, что гораздо проще исправить клиентский запрос, но мне просто интересно, можно ли решить эту проблему с внутренней стороны?)

TSR 03.09.2018 18:34

Спасибо, что у меня сработало! Я проверил запрос через скрипач и извлек тип пантомимы. Затем я поместил этот тип пантомимы в условное. if (req.headers["content-type"] === "text/plain;charset=UTF-8") { Теперь я наконец могу разобрать тело запроса

gdyrrahitis 16.08.2019 21:50

Другие вопросы по теме