我构建的演示应用使用 Express 来提供由 MongoDB 实例浇灌的一些 React 代码在 mLab 上运行并在我的主要React代码中通过SuperAgent调用检索(通过 index.html 加载)。
启动服务器并在浏览器中查看效果很好,我尝试使用Electron创建桌面版本,并且在默认情况下遇到初始数据库查询问题(' /' )GET路线。
简而言之,使用Superagent,我的应用会尝试在数据库连接之前到达数据库,并且第一个查询返回空白。如果我刷新页面,一切都在那里,所以它最终是连接的,只是因为移动到电子后时间有所改变。
自从我搬到电子公司以来,这是我的快递服务器:
const electron = require('electron');
const app = require('app');
const BrowserWindow = require('browser-window');
const express = require('express'),
db = require('./model/db'),
bodyParser = require('body-parser'),
http = require('http'),
path = require('path');
const expressApp = express();
// Keep a global reference of the window object, if you don't, the window will
// be closed automatically when the JavaScript object is garbage collected.
var mainWindow = null;
// Quit when all windows are closed.
app.on('window-all-closed', function() {
// On OS X it is common for applications and their menu bar
// to stay active until the user quits explicitly with Cmd + Q
if (process.platform != 'darwin') {
app.quit();
}
});
function onListening() {
mainWindow.loadURL('http://127.0.0.1:3000');
//mainWindow.toggleDevTools();
}
// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
app.on('ready', function() {
// Create the browser window.
mainWindow = new BrowserWindow({width: 800, height: 600});
expressApp.set('port', process.env.PORT || 3000);
expressApp.use(bodyParser.json());
expressApp.use(bodyParser.urlencoded({ extended: true }));
expressApp.use(express.static(path.join(__dirname, './')));
expressApp.get('/', function(req, res) {
res.render('index');
});
expressApp.get('/tasks/all', db.readAllTasks);
expressApp.post('/tasks/createTask', db.createTask);
expressApp.delete('/tasks/deleteTask/:id', db.deleteTask);
expressApp.put('/tasks/updateTask/:id', db.updateTask);
server = http.createServer(expressApp);
server.listen(expressApp.get('port'), function(){console.log("Listenning!")});
server.on('listening', onListening);
// Emitted when the window is closed.
mainWindow.on('closed', function() {
mainWindow = null;
});
});
在此之前服务器看起来像:
var express = require('express');
var db = require('./model/db');
var bodyParser = require('body-parser');
var http = require('http');
var path = require('path');
var app = express();
app.set('port', process.env.PORT || 3000);
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(express.static(path.join(__dirname, './')));
app.get('/', function(req, res) {
res.render('index');
});
app.get('/tasks/all', db.readAllTasks);
app.post('/tasks/createTask', db.createTask);
app.delete('/tasks/deleteTask/:id', db.deleteTask);
app.put('/tasks/updateTask/:id', db.updateTask);
http.createServer(app).listen(app.get('port'), function(){
console.log("Express server listening on port " + app.get('port'));
});
我想的可能,我需要做的就是将我的res.render转移到某种回调中?
或者,我的db.js中的某些内容可能需要更改。这是一个简短的版本:
var Task = mongoose.model( 'Task', taskSchema );
mongoose.connect( '<connection string>' );
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function(){
console.log('Connected to mongoDB');
});
var allTasks = db.collection('tasks');
function readAllTasks(req, res) {
var holster = []
allTasks.find({}).forEach(function(doc){
holster.push(doc);
}, function(){
res.send(holster);
});
}
exports.readAllTasks = readAllTasks;
我得到的错误说allTasks是未定义的,然后就在那个错误之后我得到了#34;连接到mongoDB&#34;登录到控制台,然后如果我刷新我可以从数据库中获取数据没问题。
感谢您的期待!
答案 0 :(得分:0)
可能是本机答案,但我找到了一个名为wait-for-mongo的小js文件,可以让您快速解决问题。根据他们的文档,您可以像这样包装您的res.render:
var waitForMongo = require('wait-for-mongo');
waitForMongo('<connection string>', {timeout: 1000 * 60* 2}, function(err) {
if(err) {
console.log('timeout exceeded');
} else {
console.log('mongodb comes online');
res.render();
}
});
答案 1 :(得分:0)
如此简单,我所要做的只是提升数据库的require语句。
const electron = require('electron');
const app = require('app');
const BrowserWindow = require('browser-window');
const db = require('./model/db')
const express = require('express'),
bodyParser = require('body-parser'),
http = require('http'),
path = require('path');
const expressApp = express();
我的控制台报告它正在收听,然后它告诉我它连接到数据库,但无论如何数据都加载到第一页加载。 有点奇怪。我认为更好的解决方案是只在启动数据库时启动服务器监听,但这现在可以正常工作。