javascript - db.getConnection 不是函数
问题描述
我正在尝试向我的第一个应用程序发出发布请求,但每次我去发布帖子时,它都会给我这个错误:TypeError: db.getConnection is not a function
我已经尝试了所有堆栈溢出建议,但在过去 2 天弄乱了代码之后,我似乎仍然无法让它工作。我是初学者,所以请原谅我,但这是我的代码的样子......
我的 db.js 看起来像这样....
var mysql = require('mysql');
var mainDb = mysql.createPool({
host : process.env.mysql_host,
user : process.env.mysql_user,
password : process.env.mysql_pwd,
database : process.env.mysql_db
});
exports.getConnection = function(callback) {
mainDb.getConnection(function(err, connection) {
if (err) {
console.error('error connecting: ' + err.stack);
return;
}
callback(err, connection);
});
};
我的 register.js 代码看起来像这样......
var express = require('express');
var router = express.Router();
var db = require(__dirname, 'models/db');
var bodyParser = require('body-parser');
app.use(bodyParser.urlencoded({
extended: false
}));
app.use(bodyParser.json());
router.get('/register', function(req, res, next) {
res.render('register', { title: 'Register for a free account' });
});
router.post('/register', function(req, res) {
var input = JSON.parse(JSON.stringify(req.body));
var today = new Date();
var users = {
"username": req.body.username,
"email":req.body.email,
"password":req.body.password,
"created":today,
"modified":today
};
db.getConnection(function(err, connection) {
connection.query('INSERT INTO users SET ? ', users, function(err, result) {
connection.release();
if (err) { return console.error(err); }
});
});
res.redirect('/index');
});
module.exports = router;
我不知道我的 app.js 是否与这个问题相关,但它看起来像这样......
const express = require('express');
http = require('http');
path = require('path');
session = require('express-session');
app = express();
mysql = require('mysql');
bodyParser = require('body-parser');
db = require(__dirname, 'models/db')
var index = require('./routes/index');
var register = require('./routes/register');
app.use('/', index);
app.use('/', register);
var engine = require('ejs-mate');
app.engine('ejs', engine);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: false}));
app.use(express.static(path.join(__dirname, 'public')));
var server = http.createServer(app);
var port = 8995;
server.listen(port);
module.exports = app;
当我启动 app.js 时,我没有收到任何错误,只有当我从表单发出发布请求时,错误才会显示在我的浏览器中。请帮忙!
解决方案
根据文档,您不需要使用 getConnection 方法只导出池。
推荐阅读
- python - 如何重塑 skimage.imread 读取的 png 图像
- r - 使用聚合函数的嵌套循环中的错误
- python - 如何使用python从视频中找到运动向量
- python - 如果测试方法驻留在所有测试通用的类中,如何记录测试类的名称?
- javascript - 当大量请求非常快时如何解决“套接字挂断错误”
- html - 使用存储在数据库中的值保留单选按钮和日期字段的值
- python-3.x - 检查项目是否存在而不区分大小写
- ios - 谷歌地图显示位置,但不显示标记 - swift4
- linux-kernel - 内核试图执行受 NX 保护的页面——利用尝试?
- webpack - 为什么我的浏览器在使用 webpack 对节点模块进行代码拆分后显示空白页面?