node.js & postgreSQL 初体验[二]

局部代码:模拟一个小登录的测试!

刚开始的时候忘记这NODE.JS异步问题了,怎么测都不行!

后来一顿回调啊~ OK了~! 这种方法代码的可读性很差,嵌套太多了。等等吧

等过几天再研究一下 ,解决这异步的问题!~
index.js

var um = require('./modules/user-manager');

exports.index = function(req, res){
res.render('index', { title: 'Test Login DEMO' });
um.findUserByEmail('tom@gmail.com', function(user) {
if (user == null) {
console.log('no user');
} else {
console.log(user.email);
um.getMd5Password('x', function(password) {
console.log('userpassword', user.password);
console.log('input password', password);
if (user.password != password) {
console.log('password error');
} else {
console.log('OK');
}
});
}
});
};


./modules/user-manager


var pg = require('pg');

var conString = "postgres://postgres:password@localhost/test";
var client = new pg.Client(conString);
client.connect();


var userManager = {};

userManager.findUserByEmail = function(email, callback) {
var query = client.query('SELECT * FROM person WHERE email = $1', [email]);
query.on('row', function(row, result) {
result.addRow(row);
});
query.on('end', function(result) {
if (result.rowCount == 0) {
callback(null);
} else {
callback(result.rows[0]);
}
});
}


userManager.getMd5Password = function(password, callback) {
var query = client.query('SELECT md5($1) as p', [password]);
query.on('row', function(row, result) {
callback(row.p);
});
}

module.exports = userManager;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值