简体   繁体   English

使用Node.js + Express的全局对象

[英]Global objects with Node.js + Express

I'm studying Node.js + Express, coding a basic login example. 我正在研究Node.js + Express,编写了一个基本的登录示例。 My /login route is set inside the routes/login.js file: 我的/login路由设置在route / login.js文件中:

var express = require('express');
var router = express.Router();

var mysql = require('mysql');
var connectionpool = mysql.createPool({
    host     : 'localhost',
    user     : 'user',
    password : 'pass',
    database : 'database'
});

router.post('/', function(req,res){ 
    connectionpool.getConnection(function(err, connection) {
        if (err) {
            console.error('CONNECTION error: ',err);
            res.statusCode = 503;
              res.send({
                result: 'error',
                err:    err.code
            });
        } else {
            // Do something
        }
    });
});

module.exports = router;

I was wondering: how can I make the mysql or the connectionpool visible in the entire application? 我想知道:如何使mysqlconnectionpool在整个应用程序中可见? I don't want to redeclare them on each route file I'll create. 我不想在我将创建的每个路由文件中重新声明它们。 I'm looking something like an include or require method. 我正在寻找类似include或require方法的东西。

Any idea? 任何想法?

Create a separate module to act as an interface to retrieving SQL connections like so: 创建一个单独的模块作为检索SQL连接的接口,如下所示:

    var mysql = require('mysql');
    var connectionpool = mysql.createPool({
      host     : 'localhost',
      user     : 'user',
      password : 'pass',
      database : 'database'
    });

    exports.getConnection = function (callback) {
      connectionpool.getConnection(callback);
    };

Then in another file: 然后在另一个文件中:

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

        connections.getConnection(function (err, c) { 
    // Use c as a connection 
     c.query("select * from table limit 10 ",function(err,rows){
    //this is important release part 
                c.release();
                if(!err) {
                    console.log(rows);
                }           
            });

});

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

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