Nodejs Express 鏈接Mongodb

安裝MongoDB

下載mongodbhtml

設置環境變量

將mongodb 的 安裝目錄的 E:\Program Files\MongoDB\Server\3.4\bin 寫入環境變量

啓動服務

控制檯 輸入 mongodb --dbpath E:\MongoDB\data   這後面的路徑即是數據集合的路徑 
服務啓動成功提示

啓動成功

MongoDB監聽的是27017端口,打開瀏覽器輸入http://127.0.0.1:27017,則會看到以下提示:
  It looks like you are trying to access MongoDB over HTTP on the native driver port.mongodb

若是嫌每次輸入命令打開服務麻煩的話能夠 寫成一個批處理文件 .bat 文件, 寫上代碼數據庫

start mongod --dbpath E:\MongoDB\data

安裝模塊

npm install mongoose --save

使用MongoDB

鏈接

在app.js 文件中express

// app.js

var mongoose = require('mongoose');            

mongoose.connect('mongodb://localhost/blog')     //鏈接本地數據庫blog 

var db = mongoose.connection;

// 鏈接成功
db.on('open', function(){
    console.log('MongoDB Connection Successed');
});
// 鏈接失敗
db.on('error', function(){
    console.log('MongoDB Connection Error');
});

鏈接成功後接下來寫一個 登陸註冊npm

添加登陸註冊頁面

在views模塊下添加 login.html 和register.htmljson

<!-- login.html -->

<h1>登陸頁面</h1>
   <div>
        <form action="/login" method="post">
            <p>
                <label for="username">用戶名</label>
                <input type="text" id="username" name="username" placeholder="用戶名">
            </p>
            <p>
                <label for="password">密碼 : </label>
                <input type="text" id="password" name="password" placeholder="密碼">
            </p>
            <p>
                <input type="submit" value="登陸">
            </p>
        </form>
    </div>
<!-- register.html -->
<h1>註冊頁面</h1>
    <a href="/login"> 去登陸 </a>
    <div>
        <form action="/register" method="post">
            <p>
                <label for="username">用戶名</label>
                <input type="text" id="username" name="username" placeholder="用戶名">
            </p>
            <p>
                <label for="password">密碼 :</label>
                <input type="text" id="password" name="password" placeholder="密碼">
            </p>
            <p>
                <label for="age">年齡 :</label>
                <input type="text" id="age" name="age" placeholder="年齡">
            </p>
            <p>
                <label for="address">地址 :</label>
                <input type="text" id="address" name="address" placeholder="地址">
            </p>
            <p>
                <input type="submit" value="註冊">
            </p>
        </form>
    </div>

新增Models 模塊

在根路徑下新建 Models 文件夾。 添加 users.jsapi

// Models/users.js

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

// 聲明一個數據集 對象
var userSchema = new Schema({
    username: {
        type: String,
        unique: true
    },
    password: {
        type: String
    },
    age: Number,
    address: String,
    createAt: {
        type: Date,
        default : Date.now()
    }
});
// 將數據模型暴露出去
module.exports = mongoose.model('users', userSchema);

編寫路由

// routes/index.js

var express = require('express');
var router = express.Router();
var User = require('../models/users');

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

// 這裏的業務邏輯將寫在 兩個post 路由裏 
router.post('/login', function (req, res) {

});
router.post('/register', function (req, res) {
       
});

這裏咱們須要安裝一個模塊 body-parser 用來解析post請求的參數瀏覽器

npm install body-parser --save
// app.js 

var bodyParser = require('body-parser')
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false}));

這樣咱們就能夠經過 request.body 來拿到post 請求過來的 數據了 app

先寫一個註冊的mongoose

// routes/index.js

router.post('/register', function (req, res) {

    // 獲取用戶提交的信息
    var postData = {
        username: req.body.username,
        password: req.body.password,
        age: req.body.age,
        address: req.body.address
    };
    // 查詢是否被註冊
    User.findOne({username: postData.username}, function (err, data) {
        if (data) {
            res.send('用戶名已被註冊');
        } else {
            // 保存到數據庫
            User.create(postData, function (err, data) {
                if (err) throw err;
                console.log('註冊成功');
                res.redirect('/userList');      // 重定向到所用用戶列表
            })
        }
    });
});

// 獲取全部用戶列表
router.get('/userList', function (req, res) {
    var userList = User.find({}, function (err, data) {
        if (err) throw  err;
        res.send(data)
    });
});

上面經過 mongoose 的 api 對數據庫進行操做
Mongoose Api

而後就是驗證登陸的了

router.post('/login', function (req, res) {
    var postData = {
        username: req.body.username,
        password: req.body.password
    };
    User.findOne({
        username: postData.username,
        password: postData.password
    }, function (err, data) {
        if(err) throw err;
        if(data){
            res.send('登陸成功');
        }else{
            res.send('帳號或密碼錯誤')
        }
    } )
});

到這裏就基本完成了 Express 對Mongodb 的鏈接,插入,查詢。

ps : 參考文檔 Mongoose Api

相關文章
相關標籤/搜索