1. 程式人生 > >Nodejs學習筆記(七)--- Node.js + Express 構建網站簡單示例

Nodejs學習筆記(七)--- Node.js + Express 構建網站簡單示例

目錄

前言

  這一篇主要結合前面講到的知識,去構建一個較為完整的網站應用程式,對前面學到的一些知道做一個串聯加深並靈活運用!

  功能主要用MySQL資料庫,包括登入、註冊、主頁三部分;下面就一步步開始吧!

新建專案、建立資料庫以及其它準備工作

  1.新建express + ejs 專案:sampleEjs

cd 工作目錄
express -e sampleEjs
cd sampleEjs && npm install
CREATE DATABASE IF NOT EXISTS nodesample CHARACTER SET UTF8;

USE nodesample; SET FOREIGN_KEY_CHECKS=0; DROP TABLE IF EXISTS `userinfo`; CREATE TABLE `userinfo` ( `Id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵', `UserName` varchar(64) NOT NULL COMMENT '使用者名稱', `UserPass` varchar(64) NOT NULL COMMENT '使用者密碼', PRIMARY KEY (`Id`) ) ENGINE=InnoDB DEFAULT
CHARSET=utf8 COMMENT='使用者資訊表';

  3.修改package.json檔案,安裝session和mysql模組

{
  "name": "sampleEjs",
  "version": "0.0.1",
  "private": true,
  "scripts": {
    "start": "node ./bin/www"
  },
  "dependencies": {
    "express": "~4.0.0",
    "static-favicon": "~1.0.0",
    "morgan": "~1.0.0",
    "cookie-parser": "~1.0.1",
    "body-parser": "~1.0.0",
    "debug": "~0.7.4",
    "ejs": "~0.8.5",
    "express-session" : "latest",
    "mysql" : "latest"
} }
npm install

  安裝完成後,開啟app.js檔案,新增如下程式碼

var express = require('express');
var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var session = require('express-session');

...      

//這裡傳入了一個金鑰加session id
app.use(cookieParser('Wilson'));
//使用靠就這個中介軟體
app.use(session({ secret: 'wilson'}));

...

  4.樣式和JQuery檔案

  新增以上檔案到專案中,目錄結構如下

  

  不在bootstrap包中兩個css檔案樣式如下:

body {
  min-height: 2000px;
}

.navbar-static-top {
  margin-bottom: 19px;
}
navbar-static-top.css
body {
  padding-top: 40px;
  padding-bottom: 40px;
  background-color: #eee;
}

.form-signin {
  max-width: 330px;
  padding: 15px;
  margin: 0 auto;
}
.form-signin .form-signin-heading,
.form-signin .checkbox {
  margin-bottom: 10px;
}
.form-signin .checkbox {
  font-weight: normal;
}
.form-signin .form-control {
  position: relative;
  font-size: 16px;
  height: auto;
  padding: 10px;
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
}
.form-signin .form-control:focus {
  z-index: 2;
}
.form-signin input[type="text"] {
  margin-bottom: 10px;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.form-signin input[type="password"] {
  margin-bottom: 10px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
signin.css

  5.清理專案冗餘檔案,並新增監聽

   刪除自帶的style.css檔案

   刪除routes目錄下user.js檔案,並在app.js中刪除如下程式碼

var users = require('./routes/users');

...

app.use('/users', users);

    app.js檔案中新增8000埠監聽

...
app.listen(8000);
...

  到這裡,示例環境準備完畢!

規劃路由,並新建相關檔案

  1.路由

  首頁:/

  註冊頁:/reg

  登入頁:/login

  安全退出:/logout

  (紅色表示需要新建的)

  2.routes目錄下新建如下檔案

  reg.js

  login.js

  logout.js

  3.views目錄下新建:

header.ejs

  reg.ejs

  login.ejs

  4.開啟app.js檔案,新增如下程式碼

...

var routes = require('./routes/index');
var reg = require('./routes/reg');
var login = require('./routes/login');
var logout = require('./routes/logout');

...

app.use('/', routes);
app.use('/reg', reg);
app.use('/login', login);
app.use('/logout', logout);

...

實現登入和註冊需要的資料訪問方法

  我們新建一個models資料夾,在其中新建user.js,例項程式碼如下

var mysql = require('mysql');
var DB_NAME = 'nodesample';

var pool  = mysql.createPool({
    host     : '192.168.0.200',
    user     : 'root',
    password : 'abcd'
});

pool.on('connection', function(connection) {  
    connection.query('SET SESSION auto_increment_increment=1'); 
});  

function User(user){
    this.username = user.username;
    this.userpass = user.userpass;
};
module.exports = User;

pool.getConnection(function(err, connection) {

    var useDbSql = "USE " + DB_NAME;
    connection.query(useDbSql, function (err) {
         if (err) {
            console.log("USE Error: " + err.message);
            return;
         }
         console.log('USE succeed');
    });

    //儲存資料
    User.prototype.save = function save(callback) {
        var user = {
            username: this.username,
            userpass: this.userpass
        };

        var insertUser_Sql = "INSERT INTO userinfo(id,username,userpass) VALUES(0,?,?)";

        connection.query(insertUser_Sql, [user.username, user.userpass], function (err,result) {
            if (err) {
                console.log("insertUser_Sql Error: " + err.message);
                return;
            }

            connection.release();

            console.log("invoked[save]");
            callback(err,result);                     
        });       
    };

    //根據使用者名稱得到使用者數量
    User.getUserNumByName = function getUserNumByName(username, callback) {

        var getUserNumByName_Sql = "SELECT COUNT(1) AS num FROM userinfo WHERE username = ?";

        connection.query(getUserNumByName_Sql, [username], function (err, result) {
            if (err) {
                console.log("getUserNumByName Error: " + err.message);
                return;
            }

            connection.release();

            console.log("invoked[getUserNumByName]");
            callback(err,result);                     
        });        
    };

    //根據使用者名稱得到使用者資訊
    User.getUserByUserName = function getUserNumByName(username, callback) {

        var getUserByUserName_Sql = "SELECT * FROM userinfo WHERE username = ?";

        connection.query(getUserByUserName_Sql, [username], function (err, result) {
            if (err) {
                console.log("getUserByUserName Error: " + err.message);
                return;
            }

            connection.release();

            console.log("invoked[getUserByUserName]");
            callback(err,result);                     
        });        
    };
 
});

  有這三個方法,基本登入註冊就夠了^_^!

註冊

  1.先來佈局一下HTML和CSS,加上前端驗證及一些提示資訊顯示(reg.ejs)

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">       
    <title><%= title %></title>
  
    <link rel="stylesheet" type="text/css" href="/stylesheets/bootstrap.min.css" />
    <link rel="stylesheet" type="text/css" href="/stylesheets/signin.css" />
  </head>

  <body>

    <div id="container" class="container">
       <% if (locals.success) { %> 
          <div id="alt_sucess" class="alert alert-success"> 
            <%- success %> 
          </div> 
       <% } %> 

      <% if (locals.error) { %> 
        <div id="alt_warning" class="alert alert-warning"> 
          <%= error %> 
        </div> 
      <% } %> 

      <form class="form-signin" role="form" method="post">
        <h2 class="form-signin-heading">註冊</h2>

        <input id="txtUserName" name="txtUserName" type="text" class="form-control" placeholder="使用者名稱" required autofocus />
        <input id="txtUserPwd" name="txtUserPwd" type="password" class="form-control" placeholder="密碼" required/>
        <input id="txtUserRePwd"  name="txtUserRePwd" type="password" class="form-control" placeholder="重複密碼" required/>   

        <button id="btnSub" class="btn btn-lg btn-primary" type="submit">注  冊</button>
        <a class="btn btn-link" href="/login" role="button">登  錄</a>
      </form>  
      
    </div> 
  </body>
</html>

<script src="/javascripts/jquery-1.11.1.min.js" type="text/javascript"></script>

<script type="text/javascript">
     String.prototype.format = function (args) {
            var result = this;
            if (arguments.length > 0) {
                if (arguments.length == 1 && typeof (args) == "object") {
                    for (var key in args) {
                        if (args[key] != undefined) {
                            var reg = new RegExp("({" + key + "})", "g");
                            result = result.replace(reg, args[key]);
                        }
                    }
                }
                else {
                    for (var i = 0; i < arguments.length; i++) {
                        if (arguments[i] != undefined) {
                            var reg = new RegExp("({)" + i + "(})", "g");
                            result = result.replace(reg, arguments[i]);
                        }
                    }
                }
            }
            return result;
    }

    $(function(){
        $('#btnSub').on('click',function(){
            var 
            $txtUserName = $('#txtUserName'),
            txtUserNameVal = $.trim($txtUserName.val()),            
            $txtUserPwd = $('#txtUserPwd'),
            txtUserPwdVal = $.trim($txtUserPwd.val()),
            $txtUserRePwd = $('#txtUserRePwd'),
            txtUserRePwdVal = $.trim($txtUserRePwd.val()),
            errorTip = '<div id="errorTip" class="alert alert-warning">{0}</div> ';

            $("#errorTip,#alt_sucess,#alt_warning").remove();
            
            if(txtUserNameVal.length == 0)
            {
                $("#container").prepend(errorTip.format('使用者名稱不能為空'));                
                $txtUserName.focus();
                return false;
            }

            if(txtUserPwdVal.length == 0)
            {                
                $("#container").prepend(errorTip.format('密碼不能為空'));
                $txtUserPwd.focus();
                return false;
            }

            if(txtUserRePwdVal.length == 0)
            {
                $("#container").prepend(errorTip.format('重複密碼不能為空'));                
                $txtUserRePwd.focus();
                return false;
            }

            if(txtUserPwdVal != txtUserRePwdVal)
            {                 
                 $("#container").prepend(errorTip.format('兩次密碼不一致'));      
                 $txtUserPwd.focus();
                 return false;
            }

            return true;
        })
    });

</script>

  2.實現註冊功能(reg.js)

var express = require('express'),
    router = express.Router(),
    User = require('../models/user.js'),
    crypto = require('crypto'),
    TITLE_REG = '註冊';

router.get('/', function(req, res) {
  res.render('reg',{title:TITLE_REG});
});

router.post('/', function(req, res) {
  var userName = req.body['txtUserName'],
      userPwd = req.body['txtUserPwd'],
      userRePwd = req.body['txtUserRePwd'],      
      md5 = crypto.createHash('md5');
 
      userPwd = md5.update(userPwd).digest('hex');

  var newUser = new User({
      username: userName,
      userpass: userPwd
  });

  //檢查使用者名稱是否已經存在
  User.getUserNumByName(newUser.username, function (err, results) {        
             
      if (results != null && results[0]['num'] > 0) {
          err = '使用者名稱已存在';
      }

      if (err) {
          res.locals.error = err;
          res.render('reg', { title: TITLE_REG });
          return;
      }

      newUser.save(function (err,result) {
          if (err) {
              res.locals.error = err;
              res.render('reg', { title: TITLE_REG }); 
              return;            
          }        

          if(result.insertId > 0)
          {
              res.locals.success = '註冊成功,請點選   <a class="btn btn-link" href="/login" role="button"> 登入 </a>' ;
          }
          else
          {
              res.locals.error = err;
          }
         
          res.render('reg', { title: TITLE_REG });
          });    
    });          
});

module.exports = router;

  3.執行檢視效果(命令列中cd到專案根目錄,執行: node app)

  執行程式後,在瀏覽器中輸入:  http://localhost:8000/reg   ,執行後如下圖

  

  前端提示如下圖:

  

  註冊成功後提示與檢查資料庫中插入資料!

  

  

  到這裡,註冊功能完成(比如判斷使用者名稱是否已存在等情況顯示就不列舉了,自已寫出來執行再看!)

登入

  1.先來佈局一下HTML和CSS,加上前端驗證及一些提示資訊顯示(login.ejs)

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">       
    <title><%= title %></title>
  
  <link rel="stylesheet" type="text/css" href="/stylesheets/bootstrap.min.css" />
    <link rel="stylesheet" type="text/css" href="/stylesheets/signin.css" />
  </head>

  <body>

    <div id="container" class="container">
       <% if (locals.success) { %> 
          <div id="alt_sucess" class="alert alert-success"> 
            <%- success %> 
          </div> 
       <% } %> 

      <% if (locals.error) { %> 
        <div id="alt_warning" class="alert alert-warning"> 
          <%= error %> 
        </div> 
      <% } %> 

      <form class="form-signin" role="form" method="post">
        <h2 class="form-signin-heading">登入</h2>
        <input id="txtUserName" name="txtUserName" type="text" class="form-control" placeholder="使用者名稱" required autofocus />
            <input id="txtUserPwd" name="txtUserPwd" type="password" class="form-control" placeholder="密碼" required/> 
        <label class="checkbox">
          <input name="chbRem" id="chbRem" type="checkbox" value="remember-me"> 記住密碼
        </label>              
        <button id="btnSub" class="btn btn-lg btn-primary" type="submit">登  錄</button>
        <a class="btn btn-link" href="/reg" role="button">注  冊</a>

      </form>
            
    </div> 
  </body>
</html>

<script src="/javascripts/jquery-1.11.1.min.js" type="text/javascript"></script>

<script type="text/javascript">
     String.prototype.format = function (args) {
            var result = this;
            if (arguments.length > 0) {
                if (arguments.length == 1 && typeof (args) == "object") {
                    for (var key in args) {
                        if (args[key] != undefined) {
                            var reg = new RegExp("({" + key + "})", "g");
                            result = result.replace(reg, args[key]);
                        }
                    }
                }
                else {
                    for (var i = 0; i < arguments.length; i++) {
                        if (arguments[i] != undefined) {
                            var reg = new RegExp("({)" + i + "(})", "g");
                            result = result.replace(reg, arguments[i]);
                        }
                    }
                }
            }
            return result;
    }

    $(function(){
        $('#btnSub').on('click',function(){           
            var 
            $txtUserName = $('#txtUserName'),
            txtUserNameVal = $.trim($txtUserName.val()),            
            $txtUserPwd = $('#txtUserPwd'),
            txtUserPwdVal = $.trim($txtUserPwd.val()),
            errorTip = '<div id="errorTip" class="alert alert-warning">{0}</div> ';  

            $("#errorTip,#alt_warning").remove();
            
            if(txtUserNameVal.length == 0)
            {
                $("#container").prepend(errorTip.format('使用者名稱不能為空'));                
                $txtUserName.focus();
                return false;
            }

            if(txtUserPwdVal.length == 0)
            {                
                $("#container").prepend(errorTip.format('密碼不能為空'));
                $txtUserPwd.focus();
                return false;
            }
            
            return true;                
        })
    });

</script>
login.ejs 示例

  2.再來完成後端程式碼(包括儲存session和cookies記錄密碼)

var express = require('express'),
    router = express.Router(),
    User = require('../models/user.js'),
    crypto = require('crypto'),
    TITLE_LOGIN = '登入';

router.get('/', function(req, res) {
    res.render('login',{title:TITLE_LOGIN});
});

router.post('/', function(req, res) {
    var userName = req.body['txtUserName'],
        userPwd = req.body['txtUserPwd'],
        isRem = req.body['chbRem'],
        md5 = crypto.createHash('md5');
       
    User.getUserByUserName(userName, function (err, results) {                            
        
        if(results == '')
        {
            res.locals.error = '使用者不存在';
             res.render('login',{title:TITLE_LOGIN});
             return;
        }

         userPwd = md5.update(userPwd).digest('hex');
         if(results[0].UserName != userName || results[0].UserPass != userPwd)
         {
             res.locals.error = '使用者名稱或密碼有誤';
             res.render('login',{title:TITLE_LOGIN});
             console.log(1);
             return;
         }
         else
         {
             if(isRem)
             {
                res.cookie('islogin', userName, { maxAge: 60000 });                 
             }

             res.locals.username = userName;
             req.session.username = res.locals.username;  
             console.log(req.session.username);                        
             res.redirect('/');
             return;
         }     
    });              
});

module.exports = router;
login.js

  3.執行檢視效果

  執行程式後,在瀏覽器中輸入:  http://localhost:8000/login   ,執行後如下圖

  

  提示效果如下:

  

  登入成功後,會跳轉到首頁,下面我們就著手把首頁完成!

首頁

  首頁主要為了測試登入註冊的功能是否可可用,雖然首頁基本沒什麼功能,但是我還是把它頭部放到了header.ejs檔案中!

  1.頭部HTML和CSS

<div class="navbar navbar-default navbar-static-top" role="navigation">
  <div class="container">
    <div class="navbar-header">         
      <a class="navbar-brand" href="/">Porschev - Nodejs + Express + Ejs + MySQL + Bootstrap 示例</a>
    </div>
    <div class="navbar-collapse collapse">
      <ul class="nav navbar-nav navbar-right">

        <% if (locals.username) { %> 
          <li><a href="#">        
                <%= username %>          
          </a></li>
          <li><a href="/logout">安全退出</a></li> 
        <% } %>           
      </ul>
    </div>              
  </div>
</div>
header.ejs

  2.index.ejs

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">           
      <title><%= title %></title>
    <link rel="stylesheet" type="text/css" href="/stylesheets/bootstrap.min.css" />
    <link rel="stylesheet" type="text/css" href="/stylesheets/navbar-static-top.css" />   
  </head>
  <body>
      <% include header %> 
  </body>
</html>
index.ejs

  3.index.js實現(主要是cookies,session登入狀態判斷)

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

router.get('/', function(req, res) {
  if(req.cookies.islogin)
  { 
         console.log('cookies:' + req.cookies.islogin);
       req.session.username = req.cookies.islogin;
  }  

  if(req.session.username)
  {    
          console.log('session:' + req.session.username);
        res.locals.username = req.session.username;      
  }
  else
  {
        res.redirect('/login');
        return;    
  }

  res.render('index',{title:'主頁'});
});

module.exports = router;
index.js

  4.執行,登入後,檢視效果

  登入,不勾選自動登入,執行http://localhost:8000 會自動跳到登入頁

  輸入正確的使用者名稱和密碼登入成功後,頁面顯示如下(右上角的部分顯示了使用者名稱)

  

  關閉瀏覽器,再次輸入http://localhost:8000 ,跳轉到登入頁,需要重新登入!

  再次登入,勾選自動登入

  進行首頁如上圖;

  關閉瀏覽器,再次輸入http://localhost:8000,不會跳轉到登入頁,而是直接登入了!(cookies起了作用)

  關閉瀏覽器,過一分鐘後,再輸入http://localhost:8000 ,跳轉到登入頁 (cookies失效)

安全退出

  安全退出主要就是清除session(logout.js)

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

router.get('/', function(req, res) {
  req.session.destroy();
  res.redirect('/login');
});

module.exports = router;
logout.js

  實現效果:在不是自動登入的情況下,登入後點擊安全退出,不關閉瀏覽器,通過url再訪問首頁,無法直接進入,會跳轉到登入頁!

 寫在之後

  這一篇主要是對前面所學的知識的運用,把零散的知識能真正變成能幫助你實現功能的技能!

  示例並沒有過多去優化程式碼,有很多可優化的部分,在學習的過程中去思考提升,比如:

  1.怎麼把程式碼寫的更高效和優美

  2.如果登入驗證的部分都像index.js裡那麼寫,那頁多了怎麼辦?

  3.像header.ejs一樣的提取頁面公共部分怎麼才能做得更好

  ...

  提示:

  1.上面示例中我提到了“自動登入”,而我寫的是“記錄密碼”,大家就當自動登入來用吧^_^! 

  2.關於session和cookies的實現登入和自動登入部分,示例主要為了體現運用,太懶沒有去按照實際規格去完成,有過web開發經驗的應該都知道怎麼去做以及該儲存什麼資訊,實在不清楚的留言或郵件給我吧!

相關推薦

Nodejs學習筆記Node.js + Express 構建網站簡單示例

ren 結構 crypto 中間件 實現 cmd ews path releases 前言   上一篇學習了一些構建網站會用到的一些知識點:https://www.cnblogs.com/flyingeagle/p/9192936.html   這一篇主要結合前面講到的知識

Nodejs學習筆記--- Node.js + Express 構建網站簡單示例

目錄 前言   這一篇主要結合前面講到的知識,去構建一個較為完整的網站應用程式,對前面學到的一些知道做一個串聯加深並靈活運用!   功能主要用MySQL資料庫,包括登入、註冊、主頁三部分;下面就一步步開始吧! 新建專案、建立資料庫以及其它準備工作   1.新建express + ejs

Nodejs學習筆記--- Node.js + Express 構建網站預備知識

目錄 前言   前面經過五篇Node.js的學習,基本可以開始動手構建一個網站應用了,先用這一篇瞭解一些構建網站的知識!   主要是些基礎的東西...   如何去建立路由規則、如何去提交表單並接收表單項的值、如何去給密碼加密、如何去提取頁面公共部分(相當於使用者控制元件和母版頁)等等...

Nodejs學習筆記Node.js + Express 實現上傳文件功能felixge/node-formidable

blog args 一個 type屬性 ole java mod device 前端 前言   前面講了一個構建網站的示例,這次在此基礎上再說說web的常規功能----文件上傳,示例以一個上傳圖片的功能為例子   上傳功能命名用formidable實現,示例很簡單!   P

Nodejs學習筆記--- Node.js + Express 實現上傳檔案功能felixge/node-formidable

目錄 前言   前面講了一個構建網站的示例,這次在此基礎上再說說web的常規功能----檔案上傳,示例以一個上傳圖片的功能為例子   上傳功能命名用formidable實現,示例很簡單!   PS:最近比較忙,距上一次更新已經比較久了^_^! formidable簡介   nodejs

【轉】Nodejs學習筆記--- 簡介及安裝Node.js開發環境

ack 目錄 javascrip 難度 時間 網站開發 clas jetbrains 常用 目錄 學習資料 簡介 安裝Node.js npm簡介 開發工具 Sublime Node.js開發環境配置 擴展:安裝多版本管理器 學習資料   1.深入淺出Node.j

Nodejs學習筆記--- 簡介及安裝Node.js開發環境

目錄 學習資料   2.Node.js開發指南 簡介(只撿了我覺得重要的) Node.js是讓Javascript脫離瀏覽器執行在伺服器的一個平臺,不是語言;Node.js採用的Javascript引擎是來自Google Chrome的V8;執行在瀏覽器外不用考慮頭疼的Java

Nodejs學習筆記—與MySQL交互felixge/node-mysql

ted iss eid 所在 err password soc deb 大連 簡介和安裝   Node.js與MySQL交互操作有很多庫,具體可以在 https://www.npmjs.org/search?q=mysql 查看。   我選擇了felixge/node-m

vue.js學習筆記--外掛

在日常的專案中,如果我們需要頻繁的使用某些功能,那麼最好的辦法就是將這個功能封裝成函式來使用。在vue中,我們同樣也會經常將常用的元件分離出來,這樣既便於我們的使用,同時也便於之後的維護。 同樣,當某個元件在許多專案中都要頻繁的使用,那麼我們可以將其寫成一個外掛,vue官方的文件中也

Nodejs學習筆記與MySQL互動felixge/node-mysql

                目錄簡介和安裝 測試MySQL 認識一下Connection Opti

以太坊學習筆記——Truffle整合Nodejs

這篇文章的內容緊接著上章的內容,上一篇講了truffle合約部署的基本操作,文章最後講了通過console來呼叫部署成功的合約中的方法,之所以truffle console能夠直接呼叫合約中的方式,是因

Nodejs學習筆記十四— Mongoose介紹和入門 && Nodejs學習筆記--- 與MongoDB的互動mongodb/node-mongodb-native、MongoDB入門

目錄 簡介   MongoDB    開源,高效能的NoSQL資料庫;支援索引、叢集、複製和故障轉移、各種語言的驅動程式;高伸縮性;   node-mongodb-native   mongodb的nodejs驅動; MongoDB安裝(windows)   按照官方說明在win7 64位

Nodejs學習筆記--- 與MySQL互動felixge/node-mysql

目錄 簡介和安裝   我選擇了felixge/node-mysql,用的人比較多,先隨大溜看看它的使用,暫時沒有太過糾結於各庫之間的執行效能問題,對其它庫有研究的筒子也可以分享一下效能要求較高時的選擇^_^!  This is a node.js driver for mys

Nodejs學習筆記--- 與MongoDB的互動mongodb/node-mongodb-native、MongoDB入門

目錄 簡介   MongoDB    開源,高效能的NoSQL資料庫;支援索引、叢集、複製和故障轉移、各種語言的驅動程式;高伸縮性;   node-mongodb-native   mongodb的nodejs驅動; MongoDB安裝(windows)   按照官方

mysql學習筆記—— MySQL內連接和外連接

聚集函數 信息 _id left tro 做了 學習 作用 group MySQL內連接(inner join on) MySQL的內連接使用inner join on,它的效果跟使用where是一樣的,如果聯結的是兩個表,那麽需要左右的條件或者說字段是

Spring 學習筆記—— 切入點表達式

service string 出現 targe || 參數 public 例如 語法   為了能夠靈活定義切入點位置,Spring AOP提供了多種切入點指示符。 execution———用來匹配執行方法的連接點   

EF學習筆記:讀取關聯數據

取數據 microsoft image zha 手動 模型 取數 foreach ret 總目錄:ASP.NET MVC5 及 EF6 學習筆記 - (目錄整理) 本篇參考原文鏈接:Reading Related Data 本章主要講述加載顯示關聯數據; 數據加載分為以下三

Java語言基礎學習筆記

day tez lec mdk abd err .com mar mdm 烈7A茨諳9m繁5暗MChttp://www.zcool.com.cn/collection/ZMTg3NzE1Njg=.html 3馗iC蓖17握WM啦http://www.zcool.com.cn

python學習筆記函數

限制 指向 什麽 問題 www. img 值傳遞 在線的 comment 原鏈接:http://www.cnblogs.com/vamei/archive/2012/06/01/2529500.html#!comments 函數學習遇到了問題 1 #!/usr/bin/

PHP7 學習筆記如何使用zephir編譯一個擴展記錄

ring0 hub dev conf rep repo ase comm extension 一、zephir 編譯遇到的錯誤 安裝 git clone https://github.com/phalcon/zephir $ cd zephir $ ./instal