在我的节点应用程序中使用Massive JS时,req.app.get('db')未定义

时间:2018-02-05 22:59:01

标签: javascript angular postgresql express massive

我正在使用Express,Massive JS和Postgresql构建Node应用程序。我使用sequelize但决定尝试使用Massive JS,所以我开始转换代码以使用它。

我有一个登录端点,我试图从我的Angular 5应用程序到达,我收到一个错误。此错误仅发生在我部署的应用程序上。它在本地工作没有任何问题。

以下是具体错误:

TypeError: Cannot read property &#39;get_user&#39; of undefined<br> &nbsp; &nbsp;at login (/root/firstImpression/server/features/auth/authController.js:7:26)

这是我的文件夹结构:

+Server
   -server.js
   +config
     -secrets.js
   +db
     -get_user.sql
   +features
     +auth
       -authController.js
       -authRoutes.js

server.js文件内容:

const express = require('express');
const bodyParser = require('body-parser');
const path = require('path');
const http = require('http');
const app = express();
const cookieParser = require('cookie-parser');
const secrets = require('./config/secrets');
const massive = require('massive');

// used to create, sign, and verify tokens
var jwt = require('jsonwebtoken'); 

// Parsers
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false}));
app.use(cookieParser());

//routes 
require('./features/auth/authRoutes')(app);

//Connect to database
massive(secrets.development).then(db => {
app.set('db', db);
});

// Angular DIST output folder
app.use(express.static(path.join(__dirname, '../dist')));

//Set up static files
app.use(express.static('../dist'));

// Send all other requests to the Angular app
app.get('*', (req, res) => {
res.sendFile(path.join(__dirname, '../dist/index.html'));
});

//Set Port
const port = process.env.PORT || '3000';
app.set('port', port);

const server = http.createServer(app);

server.listen(port, () => console.log(`Running on localhost:${port}`));

get_user.sql文件内容:

SELECT * FROM users WHERE username = $1;

authController.js文件内容:

const jwt     = require('jsonwebtoken');
const secrets = require('../../config/secrets');
const bcrypt  = require('bcrypt');

module.exports = {
    login: (req, res) => {
        req.app.get('db').get_user(req.body.username).then(user => {
          if(user[0]) {
            bcrypt.compare(req.body.password, user[0].password, 
            function(err, result) {
                if(result) {
                    var token = jwt.sign({user}, secrets.tokenSecret, 
                                {expiresIn: '1h'});
                    res.status(200).json({
                        token: token,
                        user: user
                    })
                } else {
                    res.status(200).json("Invalid username and/or 
                    password.");
                }
            });
        } else {
            res.status(200).json("Could not find that user.");
         }
      })
   }
}

authRoutes.js文件内容:

var authController = require('./authController');

module.exports = (app) => {

    app.post('/user-auth', authController.login);

}

此行上的authController.js文件中出现错误:

req.app.get('db').get_user(req.body.username)

我一直在阅读大量js的文档,并了解了将DB文件夹保持在初始化的同一级别的重要性,这是我的server.js文件。

正如我之前所说,当我在本地机器上运行时,它运行良好;但是,只要我将其部署到我的实时环境,就会收到错误消息。

非常感谢任何帮助或指示。如果需要任何其他信息,请告诉我,我很乐意提供。

1 个答案:

答案 0 :(得分:0)

您的应用设置可能应该像

那样换行
const express = require('express');
const bodyParser = require('body-parser');
const path = require('path');
const http = require('http');
const app = express();
const cookieParser = require('cookie-parser');
const secrets = require('./config/secrets');
const massive = require('massive');

// used to create, sign, and verify tokens
var jwt = require('jsonwebtoken'); 

//Connect to database
massive(secrets.development).then(db => {
    // Parsers
    app.use(bodyParser.json());
    app.use(bodyParser.urlencoded({ extended: false}));
    app.use(cookieParser());
    app.set('db', db);
    // Angular DIST output folder
    app.use(express.static(path.join(__dirname, '../dist')));

    //routes 
    require('./features/auth/authRoutes')(app);

    //Set up static files
    app.use(express.static('../dist'));

    // Send all other requests to the Angular app
    app.get('*', (req, res) => {
        res.sendFile(path.join(__dirname, '../dist/index.html'));
    });

    //Set Port
    const port = process.env.PORT || '3000';
    app.set('port', port);

    const server = http.createServer(app);

    server.listen(port, () => console.log(`Running on localhost:${port}`));
});