无法将数据从Angular.js发布到Node.js

时间:2018-10-15 11:04:22

标签: javascript angularjs node.js

我正在使用AngularJS和Node.js创建MEAN堆栈应用程序。

这是我的AngularJS代码:

app.js:

    var app = angular.module('crudApp', ['ngRoute']);

    app.config(['$routeProvider','$locationProvider', 
        function($routeProvider,$locationProvider){
            $routeProvider
                .when('/employees/create', {
                    templateUrl : 'create.html',
                    controller  : 'EmployeeController'
                }).when('/nothing', {
                    templateUrl : 'main.html',
                    controller  : 'mainController'
                });
            $locationProvider.html5Mode(true);
    }]);

    app.controller('EmployeeController',function($scope,$http) {
        $scope.save = function(data) {
            $scope.data = JSON.stringify(data);
            console.log(data);
            $http.post("http://localhost:8080/employees/create-employee",$scope.data).then(function(response) {
                console.log("posted successfully");
            });
        };
    });

这是我的Node.js代码:

server.js:

var express  = require('express');
var app      = express();
var cors     = require('cors');
var bodyParser = require('body-parser');
app.use(cors());

app.use(express.static(__dirname + '/angularjs/public'));

app.use(bodyParser.json());
app.use(bodyParser.urlencoded({
   extended: true
}));

app.use('*',function(req, res) {
    res.sendFile(__dirname + '/angularjs/public/index.html');
});

require('./node/routes')(app);

app.listen(8080);

routes.js:

module.exports = function(app) {
  app.get('/employees/create-employee',function(req,res) {
      console.log(req.body);
});

角度部分工作正常,在控制台中显示数据,发布数据并获得“成功发布”消息。

但是在节点中,我无法在req.body中获取发布的数据。

在浏览器“网络”中签入时,我正在获取“ create.html”内容。

需要某人的帮助。

1 个答案:

答案 0 :(得分:1)

使用此

module.exports = function(app) {
  app.post('/employees/create-employee',function(req,res) {
      console.log(req.body);
});

为了得到,您应该使用req.params

module.exports = function(app) {
  app.get('/employees/create-employee',function(req,res) {
      console.log(req.params);
});