【问题标题】:Issue with mongodb's collection.find() when used in an express app.js file在 express app.js 文件中使用 mongodb collection.find() 时出现问题
【发布时间】:2016-06-01 16:19:36
【问题描述】:

只是一点背景:我对后端代码(node js,express js)很陌生,所以请耐心等待...我正在使用 express js 和 mongodb 构建网站和 Shopify 应用程序。网站和 Shopify 应用程序都需要与同一个数据库(在这种情况下我称之为 tbapp)。因为在我决定尝试遵循this git hub repo 中编写的 express js 代码之前,我从未构建过 Shopify 应用程序。我注意到这个示例应用程序没有使用路由目录,所以没有考虑太多,我决定不使用它,并将我所有的“获取”和“发布”请求放在我的 app.js 文件中。然而,与我的应用不同的是,示例应用没有在数据库中存储任何信息...

现在是实际问题:我正在尝试查明店主是否在他们的商店管理员中输入了匹配的密钥——所以我使用了“collection.find”。当店主输入正确的密钥时,这可以正常工作,但是每当他们输入不在我的数据库中的密钥时,该函数都会返回错误——即使我已经指定当“collection.find”找不到它应该呈现的文档时带有传递给它的局部变量的页面。下面是我的 app.js 文件中的相关代码。您是否认为在路由中不使用 index.js 文件会导致此问题?这是我能想到的唯一解释,因为我确实在我的网站上做同样的事情,但唯一的区别是我的网站代码使用了路由。

这是我的 app.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 crypto= require("crypto");
var querystring= require("querystring");
var request= require("request");
var session= require("express-session");

var mongo= require("mongodb");
var monk= require("monk");
var db= monk("localhost:27017/tbapp");


var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.engine("html", require("ejs").__express);
//changed renderFile

app.set('view engine', 'html');

// 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(session({secret: 'somethingsecret', saveUninitialized: true, resave: true}));
app.use(express.static(path.join(__dirname, 'public')));

app.use(function(req, res, next){
   req.db= db;


    next();
});

这是问题代码:

app.post("/enter-store-key", function(req, res) {

    var db= req.db;
    var key= req.body.storeKey;
    var collection= db.get("businessOwners");

    console.log(key);
    collection.find({_id: key}, {}, function(err, doc) {
        if(err) {
            res.send("There was an error");
        } else {
            if(doc.length>0) {
               res.render("widg-index", {
               api_key: config.shopify_api_key,
               shop: config.shop,
               title: "Home",
               valid_key: "yes"
               }); 
            } else {
               res.render("widg-index", {
               api_key: config.shopify_api_key,
               shop: config.shop,
               title: "Home",
               valid_key: "no"
               }); 

        }
        }
    }); 

    //WHEN STORE OWNER DOESN'T INPUT A CORRECT KEY I GET AN ERROR PAGE??? IF FUNCTION "FIND" CANNOT FIND A DOCUMENT WITH SPECIFIED QUERY IT RETURNS AN ERROR?? WHYYYYYY????!!

});

感谢任何帮助我的人。我已经挣扎了一段时间,所以任何和所有的建议都将不胜感激!

【问题讨论】:

  • 您是否打印出 实际 错误。您在 err 参数中遇到的错误是什么?
  • 这是一个 500 错误。直到今天我才打印出实际的错误消息(愚蠢的我),我终于弄清楚我做错了什么。所以谢谢你帮助我到达那里:)

标签: javascript node.js mongodb express routes


【解决方案1】:

试试这个:

collection.find({_id: key}).toArray(function (err, doc) {
  if (err) {
    console.log(err);
  } else if (doc.length) {
    console.log('Found:', docs);
  } else {
    console.log('No docs found');
  }
  db.close();
});

【讨论】:

    【解决方案2】:

    所以我终于弄清楚我做错了什么......当我测试密钥是否正确时,我使用了一个不长 24 个字符的随机字母/数字字符串。问题是,对于 mongodb,它们的 id 长度必须为 24 个字符,否则函数会引发错误。

    【讨论】:

      猜你喜欢
      • 2021-06-24
      • 2019-04-17
      • 1970-01-01
      • 1970-01-01
      • 2020-08-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-12-05
      相关资源
      最近更新 更多