javascript - 如何使用 node.js 后端服务器与前端和 mongolab 数据库进行交互?

标签 javascript node.js mongodb web mlab

我正在构建一个具有简单 jquery/html/css 前端和 node.js 服务器后端的网站。如果我的前端具有从服务器请求用户信息的功能,如下所示:

function requestUser(email, password) {
    xmlhttp = new XMLHttpRequest();
    xmlhttp.open("GET", "http://localhost:8888/getUser/" + email + "/" + password, true);
    xmlhttp.onreadystatechange = function() {
        if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
           console.log(xmlhttp.responseText);
        }
    }
    xmlhttp.send();
}

我的 Node 服务器看起来像这样:

var http = require("http"),
    mongojs = require("mongojs"),
    fs = require("fs"),
    url = require("url");
    express = require("express")
var server = http.createServer(requestHandler);
server.listen(8888);
var uri = "mongodb://<dbuser>:<dbpassword>@ds036698.mongolab.com:36698/alirodatabase";
var db = mongojs(uri, ["Papers", "Users"]);
console.log("node server running back end of app");
function requestHandler(request, response) {
    //request for user is .../getUser/<username>/<password>
    var path = url.parse(request.url).pathname;
    var details = path.split('/');
    if(details.indexOf("getUser") != -1) {
        console.log("recieved request for user");
        var user = db.Users.find({"email": details[details.indexOf("getUser") + 1],
                                  "password": details[details.indexOf("getUser") + 2]});
        user = user.toArray[0];
        response.writeHead(200, {"Content-Type": "text/json"});
        response.write(JSON.stringify(user));
    }
    else {
        fs.readFile("./index.html", function(err, file) {
            if(err) {
                return 
            }
            response.writeHead(200, {"Content-Type": "text/html"});
            response.end(file, "utf-8");
        });
    }
}

为什么它不工作?当我尝试从服务器请求时,我从 firefox 收到“混合内容”和/或“corss-origin”错误。如何让 Node 服务器与站点的其余部分在同一域中运行以避免这些错误?

最佳答案

真的很难阅读你的代码,我明白你想做什么,但让我首先建议一个更好的结构,更容易阅读,理解并为你的服务器实现更多路由,请检查这里:

var express = require('express'),
  cors = require('cors'),
  app = express();

app.use(cors());

app.get('/getUser/:user/:passwd', function(req, res, next) {
  // Perform all mongo operations here using req.params.user and req.params.passwd
  // and in the callback send a response like the object below
  res.json({
    msg: 'This is CORS-enabled for all origins!',
    user: req.params.user,
    passwd: req.params.passwd
  });
});

app.listen(8888, function() {
  console.log('CORS-enabled web server listening on port 8888');
});

还缺少 CORS 支持 ( https://developer.mozilla.org/en-US/docs/Web/HTTP/Access_control_CORS ),因为如果您计划托管使用托管在不同服务器中的此服务的静态文件,您将在用例中需要它,因此让我们使用此模块:https://www.npmjs.com/package/cors 它将允许 express 处理来自任何地方的请求。

关于javascript - 如何使用 node.js 后端服务器与前端和 mongolab 数据库进行交互?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31945152/

相关文章:

javascript - TypeScript Setter 编译错误但它仍然执行其工作?

javascript - 如何使具有多个绝对定位元素的 div 响应

javascript - 从浏览器检索数据到 JavaScript

mysql/node.js - 删除不存在的记录时抛出错误

node.js - 类型错误,具有唯一的 :true in entity instance

angularjs - BeanStalk 服务器中不显示图像

mongodb - 简单Map/Reduce MongoVUE

node.js - 我如何在 Mongoose 聚合中使用字段值? ( Node )

javascript - 在 parse.com 中使用回调函数时如何保留范围?

node.js - Socket.io 和 Express3 - 客户端请求 404/socket.io/socket.io.js