繁体   English   中英

Node.js API在终端中返回JSON,但在浏览器中未返回

[英]Node.js API returns JSON in terminal but not in browser

有一个奇怪的问题。 一直在寻找答案,但没有发现。 我正在做一个节点api教程,当我执行任何GET请求时,它将从我的终端中的mongoDB数据库返回JSON,但是在我的浏览器或邮递员中,我什么也没回来,只有在终端中,我才得到任何响应。 当我在邮递员中尝试POST时,它说它无法连接到后端。

这是我的代码:

var http = require('http');
var url = require('url');
var database = require('./database');


// Generic find methods (GET)

function findAllResources(resourceName, req, res) {
  database.find('OrderBase', resourceName, {}, function (err, resources) {
  res.writeHead(200, {'Content-Type': 'application/json'});
  res.end(JSON.stringify(resources));
  });
};

var findResourceById = function (resourceName, id, req, res) {
  database.find('OrderBase', resourceName, {'_id': id}, function (err, resource) {
  res.writeHead(200, {'Content-Type': 'application/json'});
  res.end(JSON.stringify(resource));
  });
};

// Product methods

var findAllProducts = function (req, res) {
  findAllResources('Products', req, res);
};

var findProductById = function (id, req, res) {
  findResourceById('Products', id, req, res);
};

// Generic insert/update methods (POST, PUT)

var insertResource = function (resourceName, resource, req, res) {
  database.insert('OrderBase', resourceName, resource, function (err, resource) {
  res.writeHead(200, {'Content-Type': 'application/json'});
  res.end(JSON.stringify(resource));
  });
};

// Product methods

var insertProduct = function (product, req, res) {
  insertResource('OrderBase', 'Product', product, function (err, result) {
  res.writeHead(200, {'Content-Type': 'application/json'});
  res.end(JSON.stringify(result));
  });
};


var server = http.createServer(function (req, res) {

  // Break down the incoming URL into its components
  var parsedURL = url.parse(req.url, true);

  // determine a response based on the URL
  switch (parsedURL.pathname) {
    case '/api/products':
    if (req.method === 'GET') {
      // Find and return the product with the given id
      if (parsedURL.query.id) {
        findProductById(id, req, res)
      }
      // There is no id specified, return all products
      else {
        findAllProducts(req, res);
      }
    }
    else if (req.method === 'POST') {

      //Extract the data stored in the POST body
      var body = '';
      req.on('data', function (dataChunk) {
        body += dataChunk;
      });
      req.on('end', function () {
        // Done pulling data from the POST body.
        // Turn it into JSON and proceed to store it in the database.
        var postJSON = JSON.parse(body);
        insertProduct(postJSON, req, res);
      });
    }
    break;
    default:
    res.end('You shall not pass!');
  }
});
server.listen(8080);

console.log('Up and running, ready for action!');

您有几个以err作为第一个参数的回调,但是您并未处理任何潜在的错误。 这意味着如果出了什么问题,您就不会捕获并返回错误。 我不知道这是否与它有关,而是作为一种实践(甚至不是“最佳”,而是一般实践)而不是这样做

function (err, resource) {
  res.writeHead(200, {'Content-Type': 'application/json'});
  res.end(JSON.stringify(resource));
  }

做这个

function (err, resource) {
  if(err){
    // do something to warn the client and stop here
  }
  res.writeHead(200, {'Content-Type': 'application/json'});
  res.end(JSON.stringify(resource));
  }

尝试一下,在尝试输出答案之前,先查看是否确实遇到错误。

https://nodejs.org/api/http.html#http_response_end_data_encoding_callback

响应结束方法不向响应套接字发送数据。 也许你改变它

res.writeHead(200, {'Content-Type': 'application/json'});
res.end(JSON.stringify(resource));

res.writeHead(200, {'Content-Type': 'application/json'});
res.write(JSON.stringify(resource));
res.end();

如果您想关闭套接字以执行某项操作,则可以进入回调结束。

res.end(#logHandle());
var MongoClient = require('mongodb').MongoClient;

var assert = require('assert');


var connect = function  (databaseName, callback) {
var url = 'mongodb://localhost:27017/' + databaseName;

MongoClient.connect(url, function  (error, database) {
    assert.equal(null, error);

    console.log("Successfully connected to MongoDB instance!");

    callback(database);
})
};


exports.find = function  (databaseName, collectioName, query, callback) {
connect(databaseName, function  (database) {
    var collection = database.collection(collectioName);

    collection.find(query).toArray(
        function  (err, documents) {
            assert.equal(err, null);

            console.log('MongoDB returned the following documents:');
            console.dir(JSON.parse(JSON.stringify(documents)));
            //console.dir(documents);
            callback(null, documents);
        }
    )

    database.close();
})
};

我认为我们正在经历同一教程,这是我对“ database.js”的解决方案,对我来说有效。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM