开发者问题收集

无法读取未定义的属性“查询” - MySQL NodeJS

2018-12-27
7199

当我尝试向我的 node js 服务器发出 post 请求时,我遇到了这种类型的错误。 我在这里链接了错误和两个文件,以便您可以更好地了解我所做的事情。

TypeError: Cannot read property 'query' of undefined
    at checkIfUserCodeExist (/usr/my_server/addReferFriend.js:13:29)
    [...]

我有两个文件: app.js 和 addReferFriend.js

app.js:

var express = require('express');
var path = require('path');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var mysql= require('mysql2');
var http = require('http');
var app = express();

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

app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));


app.use(async function(req, res, next) {
  try {
    if( req.dbConnection ) {
      // ensure that req.dbConnection was not set already by another middleware
      throw new Error('req.dbConnection was already set')
    }

    let connection = mysql.createConnection({
            host: 'xx',
        user: 'xx',
        password: 'xx',
        database: 'xx'
    });

    res.on("finish", function() {
      // end the connection after the resonponse was send
      req.dbConnection.end()
    });

    // wait for the connection and assign it to the request
    req.dbConnection = await connection.connect();
    next();
  } catch(err) {
    next(err);
  }
});

app.use('/api/addReferFriend', addReferFriend);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

module.exports = app;
var server = http.createServer(app);
server.listen(3955);

和 addReferFriend.js:

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

/* GET users listing. */
router.post('/', function(req, res, next) {
  var uid = req.body.uid;
  var friendReferCode = req.body.friendReferCode;

  var sqlCheckIfExist = "SELECT my_refer FROM hub_user WHERE my_refer = '" + friendReferCode + "'";
  var sqlCodeCheckSameAsMine = "SELECT my_refer FROM hub_user WHERE uid = '" + uid + "'";

  function checkIfUserCodeExist() {
    return req.dbConnection.query(sqlCheckIfExist)
      .then(([rows, fields]) => {
        if (rows == 0) {
          console.log("Non esiste!")

          return res.send(JSON.stringify({
            "status": 500,
            "response": "codeNotExist"
          }));
        }
        console.log("Esiste!")
        console.log(rows[0].my_refer);
        return checkIfCodeIsSameAsMine(connection)
      })
  }

  function checkIfCodeIsSameAsMine() {
    return req.dbConnection.query(sqlCodeCheckSameAsMine)
      .then(([rows, fields]) => {
        if (rows == friendReferCode) {
          console.log("Codice uguale!")
          return res.send(JSON.stringify({
            "status": 500,
            "response": "sameCodeAsMine"
          }));
        }
        console.log("Codice non uguale!")
      })
  }

  checkIfUserCodeExist()
   .catch(next)
});
module.exports = router;

我正在使用 Mysql2。有人能帮我修复错误吗?

提前谢谢, Michele。

3个回答

使用此包: - const mysql = require('mysql2/promise');

`app.use(async function (req, res, next) {
if (req.dbConnection) {
    next();
}
mysql.createConnection({
    host: 'xx',
    user: 'xx',
    password: 'xx',
    database: 'xx'
}).then((conn) => {
    req.dbConnection = conn;
    next();
}).catch((error) => {
    next(error);
});

});`

并替换此代码:

 module.exports = app;
 var server = http.createServer(app);
 server.listen(3955);

为此:

app.listen(3955, () => {
    console.log("Server listening on port : " + 3955);
});
module.exports = app;

您必须控制 addReferFriend.js 并删除脚本末尾的 catch

A.Mlaouhi
2018-12-28

main.js 中, app.use('/api/addReferFriend', addReferFriend); 必须位于 app.use(async function(req, res, next) { .. let connection = mysql.createConnection( ... }) 之后 ,因为中间件是按照注册的顺序执行的。

2018-12-27

connection.connect() 返回 void( 检查源代码 );因此 req.dbConnection 设置为未定义。
您必须等待 connect 事件,然后将连接绑定到 req ,最后调用 next


否则,在快速阅读 mysql2 文档后,您可以使用此中间件简化:

app.use(function(req, res, next) {
  if (req.dbConnection) {
    next();
  }
  else {
    req.dbConnection = mysql.createConnection({
      host: 'xx',
      user: 'xx',
      password: 'xx',
      database: 'xx'
    });
    next();
  }
})

在我看来,您必须创建一次连接,而不是每次请求时都创建。

Walter Barbagallo
2018-12-27