国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

nodejs同步調(diào)用獲取mysql數(shù)據(jù)時(shí)遇到的大坑

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:00:22
文檔

nodejs同步調(diào)用獲取mysql數(shù)據(jù)時(shí)遇到的大坑

nodejs同步調(diào)用獲取mysql數(shù)據(jù)時(shí)遇到的大坑:mysql調(diào)用獲取數(shù)據(jù),只能是異步方式返回結(jié)果,不能同步獲取結(jié)果,因此,須在回調(diào)函數(shù)中編寫處理事件。期間看了下Aysnc.js,是用于多個(gè)要返回回調(diào)函數(shù)的事件,將這些事件有序的組織起來,最后只返回一個(gè)回調(diào)函數(shù),并沒有改變異步的本質(zhì),而是將多個(gè)異步整合為
推薦度:
導(dǎo)讀nodejs同步調(diào)用獲取mysql數(shù)據(jù)時(shí)遇到的大坑:mysql調(diào)用獲取數(shù)據(jù),只能是異步方式返回結(jié)果,不能同步獲取結(jié)果,因此,須在回調(diào)函數(shù)中編寫處理事件。期間看了下Aysnc.js,是用于多個(gè)要返回回調(diào)函數(shù)的事件,將這些事件有序的組織起來,最后只返回一個(gè)回調(diào)函數(shù),并沒有改變異步的本質(zhì),而是將多個(gè)異步整合為

mysql調(diào)用獲取數(shù)據(jù),只能是異步方式返回結(jié)果,不能同步獲取結(jié)果,因此,須在回調(diào)函數(shù)中編寫處理事件。期間看了下Aysnc.js,是用于多個(gè)要返回回調(diào)函數(shù)的事件,將這些事件有序的組織起來,最后只返回一個(gè)回調(diào)函數(shù),并沒有改變異步的本質(zhì),而是將多個(gè)異步整合為一個(gè)異步,從而滿足寫程序的需求。

錯(cuò)誤示范

獲取數(shù)據(jù)庫(kù)中的數(shù)據(jù)函數(shù)

var _getUser = function(name) {
 var sql = "SELECT * FROM " + TABLE + " WHERE user_loginname='" + name + "'";
 connection.query(sql, function(err, results) {
 if(!err) {
 var res = hasUser(results);
 return res;
 }else {
 return error();
 }
 });
 function hasUser(results) {
 if(results.length == 0) {
 return {err: 1, msg: "此用戶名不存在"};
 }
 else {
 return results[0];
 }
 }
 function error() {
 return {err: 1, msg: "數(shù)據(jù)庫(kù)出錯(cuò)"};
 }
}
var getUser = function(name){
 return _getUser(name);
}

獲取結(jié)果處理事件

//獲取post上來的 data數(shù)據(jù)中 uname的值
var uname = req.body.uname; 
var User = getUser(uname);
if(User.err){
 res.status(404)
 } else {
 var upwd = md5 (req.body.upwd);
 //查詢到匹配用戶名的信息,但相應(yīng)的password屬性不匹配
 if(upwd != User.user_passwd){ 
 req.session.error = "密碼錯(cuò)誤";
 res.send(404);
 // res.redirect("/login");
 }else{ 
 //信息匹配成功,則將此對(duì)象(匹配到的user) 賦給session.user 并返回成功 
 req.session.user = {name: uname, password: upwd};
 res.status(200).send("success")
 // res.send(200);
 // res.redirect("/home");
 }
 }
// md5方式加密
function md5 (text) {
 return crypto.createHash('md5').update(text).digest('hex');
};

正確示范

獲取數(shù)據(jù)庫(kù)中的數(shù)據(jù)函數(shù)

var _getUser = function(name, callback) {
 var sql = "SELECT * FROM " + TABLE + " WHERE user_loginname='" + name + "'";
 connection.query(sql, function(err, results) {
 if(!err) {
 var res = hasUser(results)
 callback(res);
 }else {
 callback(error());
 }
 });
 function hasUser(results) {
 if(results.length == 0) {
 return {err: 1, msg: "此用戶名不存在"};
 }
 else {
 return results[0];
 }
 }
 function error() {
 return {err: 1, msg: "數(shù)據(jù)庫(kù)出錯(cuò)"};
 }
}
var getUser = function(name, callback){
 return _getUser(name, callback);
}

獲取結(jié)果處理事件

//獲取post上來的 data數(shù)據(jù)中 uname的值
var uname = req.body.uname; 
getUser(uname, function(data){
 var User = data;
 if(User.err){
 res.status(404)
 } else {
 var upwd = md5 (req.body.upwd);
 //查詢到匹配用戶名的信息,但相應(yīng)的password屬性不匹配
 if(upwd != User.user_passwd){ 
 req.session.error = "密碼錯(cuò)誤";
 res.send(404);
 // res.redirect("/login");
 }else{ 
 //信息匹配成功,則將此對(duì)象(匹配到的user) 賦給session.user 并返回成功 
 req.session.user = {name: uname, password: upwd};
 res.status(200).send("success")
 // res.send(200);
 // res.redirect("/home");
 }
 }
});
// md5方式加密
function md5 (text) {
 return crypto.createHash('md5').update(text).digest('hex');
};

總結(jié)

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

nodejs同步調(diào)用獲取mysql數(shù)據(jù)時(shí)遇到的大坑

nodejs同步調(diào)用獲取mysql數(shù)據(jù)時(shí)遇到的大坑:mysql調(diào)用獲取數(shù)據(jù),只能是異步方式返回結(jié)果,不能同步獲取結(jié)果,因此,須在回調(diào)函數(shù)中編寫處理事件。期間看了下Aysnc.js,是用于多個(gè)要返回回調(diào)函數(shù)的事件,將這些事件有序的組織起來,最后只返回一個(gè)回調(diào)函數(shù),并沒有改變異步的本質(zhì),而是將多個(gè)異步整合為
推薦度:
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产成人久久精品一区二区三区 | 中文在线第一页 | 老司机精品视频一区二区 | 天堂精品高清1区2区3区 | 国产精品国产亚洲精品看不卡 | 黄色网站在线观看视频 | 不卡视频在线 | 色另类 | 久久久久久久99久久久毒国产 | 中文字幕精品一区二区精品 | 欧美精品一区二区在线观看播放 | 黄色二级毛片 | 日韩一二三 | 天天操夜夜做 | 久久免费国产精品一区二区 | 日韩欧美视频在线播放 | 麻豆精品国产 | 欧美另类日韩中文色综合 | 久久综合精品国产一区二区三区 | 91专区 | 亚洲欧美综合图区官网 | 欧美日韩欧美日韩 | 欧美在线网址 | 国产欧美日韩第一页 | 久久成人精品 | 国产第一页视频 | 美女一级毛片视频 | 欧美三级精品 | 一区二区影视 | 亚洲高清色 | 久久国产经典 | 国内精品久久久久久久久 | 日韩视频区| 亚洲精品国产精品乱码不97 | 中文字幕日韩一区二区三区不卡 | 国产成人综合精品一区 | 欧美一级淫片吊带丝袜 | 亚洲视频在线观看视频 | 国产成人免费在线视频 | 国产黑色丝袜一区在线 | 久久精品一|