json - Angular2 http.post 和未定义的 req.body

标签 json node.js http post angular

我在从 http.post 接收 json 时遇到问题。让我们说清楚一点: 这是我的组件文件:

import {Component} from 'angular2/core'
import {Http, HTTP_PROVIDERS, Headers} from 'angular2/http'

@Component({
  selector: 'login-form',
  template: `
    <form (ngSubmit)="onSubmit()">

      <button type="submit">Wyslij</button>
    </form>
  `
})

export class LoginFormComponent {
  constructor(public http: Http) { }

  onSubmit() {
    var headers = new Headers();
    headers.append('Content-Type', 'application/x-www-form-urlencoded');

    var data = JSON.stringify({
      login: "zupa",
    });

    this.http.post('http://localhost:8080/send', data, {headers: headers})
    .subscribe();
  }
}

我的 server.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 routes = require('./routes/index');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.use(express.static(path.join(__dirname, 'node_modules')));
app.use(express.static(path.join(__dirname)));
app.set('view engine', 'ejs');
app.engine('html', require('ejs').renderFile);

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

app.use('/', routes);

app.get('*', function(req, res, next) {
  res.render("index.html", {title: 'Aplikacja'});
});

app.listen(8080, function() {
  console.log("Starting at localhost:8080");
});

module.exports = app;

如你所见,这是一个标准的由express模块​​生成的服务器文件。

这是我的“路线”文件的内容。

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

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

router.post('/send', function(req, res, next) {
  console.log("Received data: " + req.body.login);
});

module.exports = router;

服务器向我返回一条消息:“接收到的数据:未定义”,我不知道为什么 req.body.login 未定义。你能帮助我吗?提前谢谢你。

PS:我用的时候也是这样

"login": "zupa"

代替

login: "zupa"

最佳答案

您应该设置适当的 header ,因为您使用的是 JSON。

headers.append('Content-Type', 'application/json');

关于json - Angular2 http.post 和未定义的 req.body,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34769784/

相关文章:

http - 如何测试 http 请求处理程序

php - JSON_BIGINT_AS_STRING 在 php 5.5 中被删除?

node.js - 为什么即使从官方网站安装 npm(以及一般程序)也会出现弃用问题?

angular - 链接 HTTP promise 时如何调用 catch 方法?

node.js - 在树莓派 3 上安装 Electron js 时出现问题

javascript - 如何使用 node.js javascript 将 JSON 转换为类似树的对象?

rest - 无法处理请求的 HTTP 状态码

asp.net-mvc - 您如何处理对返回除 ViewResult 以外的结果的操作的授权?

ios - 如何在UITableView中添加分页?

javascript - JSON 中的变量