下載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
在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 文件夾。 添加 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