簡體   English   中英

從Nodejs發送請求到Nodejs

[英]Post Request from Nodejs to Nodejs

我有一個nodejs-express服務器(1) ,它通過Angularjs與nodejs-express中的mongodb和web服務器(2)進行通信。 我正在嘗試發送一個帖子請求1-> 2但我得到405 Method Not Allowed (嘗試使用郵遞員)如果我檢查標題選項卡它顯示: Allow →GET, HEAD, OPTIONS

app.js - 從1發布方法:

function sendToDashboard(jsonData) {
        console.log ("I am here in node: ", jsonData);

        request({
          uri: "http://******.com:9000/getQueryJson",
          method: "POST",
          timeout: 10000,
          followRedirect: true,
          maxRedirects: 10
        }, function(error, response, body) {
          console.log(body);
        });
}

server / app.js - 從2獲取方法:

var bodyParser = require("body-parser"); // Require Body parser module
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var express = require('express');
var path = require('path');
var app   = require('express')(); // Require Express module
var http = require('http').Server(app); // Http server
var bodyParser = require("body-parser"); // Require Body parser module

    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.all('*', function(req, res,next) {


        /**
         * Response settings
         * @type {Object}
         */
        var responseSettings = {
            "AccessControlAllowOrigin": req.headers.origin,
            "AccessControlAllowHeaders": "Content-Type,X-CSRF-Token, X-Requested-With, Accept, Accept-Version, Content-Length, Content-MD5,  Date, X-Api-Version, X-File-Name",
            "AccessControlAllowMethods": "POST, GET, PUT, DELETE, OPTIONS",
            "AccessControlAllowCredentials": true
        };

        /**
         * Headers
         */
        res.header("Access-Control-Allow-Credentials", responseSettings.AccessControlAllowCredentials);
        res.header("Access-Control-Allow-Origin",  responseSettings.AccessControlAllowOrigin);
        res.header("Access-Control-Allow-Headers", (req.headers['access-control-request-headers']) ? req.headers['access-control-request-headers'] : "x-requested-with");
        res.header("Access-Control-Allow-Methods", (req.headers['access-control-request-method']) ? req.headers['access-control-request-method'] : responseSettings.AccessControlAllowMethods);

        if ('OPTIONS' == req.method) {
            res.send(200);  
        }
        else {
            next();
        }


});

app.post('/getQueryJson', function(request, response) {
        console.log ("I got here");
        if(response.statusCode == 200) { 

          console.log("TESTING......")
          console.log("This is your request: ", request.body);   

          console.log("This is your request: ", JSON.stringify(request.body))
          response.send("Query Received");
        }else{
          response.send(" Error code: " + response.statusCode);
        }
    });


http.listen(9000,function(){
    console.log("Connected & Listen to port 9000");
});

文件結構:

(服務器1)

在此輸入圖像描述

(服務器2)

在此輸入圖像描述

知道為什么它找不到我的方法嗎? 任何幫助將不勝感激!

如果有人遇到類似的問題,我解決了我的問題。 故障是我使用gulp運行/編譯Web服務器的方式。 以下是我的案例:

   gulp.task('connect', ['styles'], function() {
        var serveStatic = require('serve-static');
        var express        = require('express');
        var app            = express();
        var bodyParser     = require('body-parser');
        var methodOverride = require('method-override');


        var port = process.env.PORT || 9000;

        // added this part ==================================================
        app.use(bodyParser.json()); // parse application/json 
        app.use(bodyParser.json({ type: 'application/vnd.api+json' })); // parse application/vnd.api+json as json
        app.use(bodyParser.urlencoded({ extended: true })); // parse application/x-www-form-urlencoded
        app.use(methodOverride('X-HTTP-Method-Override')); // override with the X-HTTP-Method-Override header in the request. simulate DELETE/PUT
        // ==================================================

        app.use(serveStatic('.tmp'));
        app.use(serveStatic('app'));
        app.use(express.static(__dirname + 'public')); // set the static files location /public/img will be /img for users
        app.use('/bower_components', serveStatic('bower_components'));

        // and this one ==================================================
        require('./server/app')(app); // pass our application into our routes 
        //  ===============================================


        app.listen(port);   
        console.log('Magic happens on port ' + port);           // shoutout to the user
        exports = module.exports = app;                         // expose app

    });

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM