<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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)前位置: 首頁 - 科技 - 知識百科 - 正文

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

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

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

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

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

        錯誤示范

        獲取數(shù)據(jù)庫中的數(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ù)庫出錯"};
         }
        }
        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 = "密碼錯誤";
         res.send(404);
         // res.redirect("/login");
         }else{ 
         //信息匹配成功,則將此對象(匹配到的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ù)庫中的數(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ù)庫出錯"};
         }
        }
        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 = "密碼錯誤";
         res.send(404);
         // res.redirect("/login");
         }else{ 
         //信息匹配成功,則將此對象(匹配到的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)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

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

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

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 99re6在线视频精品免费下载 | 亚洲AV无码不卡在线播放| 精品亚洲视频在线| 免费无码一区二区三区蜜桃大| 亚洲一级片在线播放| 日本黄网站动漫视频免费| 亚洲美女激情视频| 成人免费黄色网址| 在线精品亚洲一区二区| 麻豆国产精品入口免费观看| 无码色偷偷亚洲国内自拍| 亚洲国产一级在线观看| 一级做a爰片久久免费| 亚洲色无码一区二区三区| 国产午夜成人免费看片无遮挡| 亚洲av色福利天堂| 日本免费网址大全在线观看| 亚洲中文字幕久久精品无码VA| 国产小视频免费观看| 两个人看的www视频免费完整版| 亚洲AV无码成人专区片在线观看| 91麻豆最新在线人成免费观看 | 亚洲精品白色在线发布| 桃子视频在线观看高清免费完整| 亚洲最大天堂无码精品区| 国产在线观看免费视频播放器| 一个人看的免费高清视频日本| 久久久久亚洲AV无码专区首| 免费A级毛片无码无遮挡内射| 国产精品亚洲色图| 亚洲成A人片在线观看WWW| 亚洲免费综合色在线视频| 免费毛片毛片网址| 亚洲AV成人精品网站在线播放| 国产麻豆视频免费观看| 午夜免费国产体验区免费的| 亚洲三级电影网址| 日产国产精品亚洲系列| 中文字幕视频免费| 乱人伦中文视频在线观看免费| 亚洲黄色在线视频|