成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Node+Express+MongoDB如何實(shí)現(xiàn)登錄注冊(cè)功能

小編給大家分享一下Node+Express+MongoDB如何實(shí)現(xiàn)登錄注冊(cè)功能,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

我們提供的服務(wù)有:成都做網(wǎng)站、網(wǎng)站建設(shè)、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、南康ssl等。為上千企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢(xún)和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的南康網(wǎng)站制作公司

注入MongoDB 依賴(lài)

var mongoose = require("mongoose");

由于需要進(jìn)行表單處理,需要用到bodyParser中間件

bodyParser模塊來(lái)做文件解析,將表單里的數(shù)據(jù)進(jìn)行格式化

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

登錄后將用戶(hù)信息保存下來(lái),需要使用session中間件,它依賴(lài)cookieParser中間件

var cookieParser = require('cookie-parser');
var session = require('express-session');
ar mongoStore = require('connect-mongo')(session);
var dbUrl = 'mongodb://localhost/express';
app.use(cookieParser()); 
app.use(session({
 secret:'express',
 store: new mongoStore({
 url: dbUrl,
 collection: 'sessions'
 })
}));

使用jade模板

layout.jade

doctype html
html
 head
  meta(charset='utf-8')
  title #{title}
  include ./includes/head
 body
  include ./includes/header
  block content

head.jade

link(href='css/main.css', rel='stylesheet')
link(href="/libs/bootstrap/dist/css/bootstrap.min.css" rel="external nofollow" , rel="stylesheet")
script(src="/libs/jquery/dist/jquery.min.js")
script(src="/libs/bootstrap/dist/js/bootstrap.min.js")

header.jade

.container
 .row
  .page-header
   h2 #{title}
.navbar.navbar-default.navbar-fixed-bottom
 .container
  if user
   p.navbar-text.navbar-right
    span 歡迎你,#{user.name}
    span  | 
    a.navbar-link(href="/layout" rel="external nofollow" ) 退出登錄
  else
   p.navbar-text.navbar-right
    a.navbar-link(href="/signup" rel="external nofollow" , data-toggle="modal", data-target="#signupModal") 注冊(cè)
    span  | 
    a.navbar-link(href="/login" rel="external nofollow" , data-toggle="modal", data-target="#signinModal") 登錄

signup.jade

include ../layout
 block content
  form.form-horizontal( role="form", method="POST", action='/user/signup')
   .form-group
    label.col-sm-2.control-label(for="signupName") 用戶(hù)名
    .col-sm-10
     input#signupName.form-control(type="text", name="user[name]", placeholder="輸入用戶(hù)名")
   .form-group
    label.col-sm-2.control-label(for="signuppassword") 密碼
    .col-sm-10
     input#signuppassword.form-control(type="password", name="user[password]", placeholder="輸入密碼")
   .form-group
    label.col-sm-2.control-label(for="signupemail") 郵箱
    .col-sm-10
     input#signupemail.form-control(type="email", name="user[email]", placeholder="輸入郵箱")
   .form-group
    .col-sm-offset-2.col-sm-10
     button.btn.btn-default(type="submit") 完成注冊(cè)

配置路由

登錄注冊(cè)頁(yè)面

// 注冊(cè)頁(yè)面
app.get('/signup', function (req,res) {
 res.render('signup', {
 title: '注冊(cè)'
 });
});
// 登錄頁(yè)面
app.get('/login', function (req,res) {
 res.render('login', {
 title: '登錄'
 });
});

注冊(cè)功能

// 注冊(cè)表單
app.post('/user/signup', function (req,res) {
 var _user = req.body.user;
 User.findOne({name:_user.name}, function (err, user) {
 if(err){
  console.log(err);
 }
 if(user) {
  return res.redirect('/login');
 } else {
  var user = new User(_user);
  user.save(function (err, user) {
  if(err){
   console.log(err);
   res.redirect('/signup');
  }
  console.log('注冊(cè)成功——用戶(hù)名:' + user);
  res.redirect('/login'); 
  });
 }
 });
});

登錄功能

// 登錄表單
app.post('/user/login', function (req,res) {
 var _user = req.body.user;
 var name = _user.name;
 var password = _user.password;
 User.findOne({name:name}, function (err, user) {
 if(err){
  console.log(err);
 }
 if(!user) {
  return res.redirect('/signup');
 }
 user.comparePassword(password, function (err, isMatch) {
  if (err){
  console.log(err);
  }
  if (isMatch) {
  req.session.user = user; // 用戶(hù)名存入session中
  console.log('登錄成功——用戶(hù)名: ' + user);
  return res.redirect('/');
  } else {
  return res.redirect('/lgoin');
  }
 });
 });
});

退出登錄

app.get('/layout', function(req,res){
 delete req.session.user;
 //delete app.locals.user; // 刪除全局變量user,否則點(diǎn)擊退出登錄,頁(yè)面無(wú)變化
 res.redirect('/');
});

登錄注冊(cè)的數(shù)據(jù)庫(kù)操作

連接數(shù)據(jù)庫(kù)

mongoose.connect("mongodb://localhost/express"); // 連接數(shù)據(jù)庫(kù)

schema模式定義

數(shù)據(jù)的更新和查找,以及密碼加鹽

//schemas/user.js
var mongoose = require('mongoose');
var bcrypt = require('bcrypt');
var SALT_WORK_FSCTOR = 10; // 計(jì)算強(qiáng)度,越大破解越困難
var UserSchema = new mongoose.Schema({
 name: {
 unique: true,
 type:String
 },
 password: String,
 email:String,
 meta: {
 createAt: {
  type: Date,
  default: Date.now()
 },
 updateAt: {
  type: Date,
  default: Date.now()
 }
 }
});
//每次存入數(shù)據(jù)時(shí)都進(jìn)行判斷
UserSchema.pre('save', function (next) {
 var user = this;
 if (this.isNew) { // 數(shù)據(jù)是新數(shù)據(jù)
 this.meta.createAt = this.meta.updateAt = Date.now();
 } else {
 this.meta.updateAt = Date.now();
 }
 //密碼 加鹽
 bcrypt.genSalt(SALT_WORK_FSCTOR, function (err, salt) {
 if (err) {
  return next(err);
 }
 bcrypt.hash(user.password, salt, function (err, hash) {
  if (err) {
  return next(err);
  }
  user.password = hash;
  next();
 });
 });
});
UserSchema.methods = {
 comparePassword: function (_password, cb) {
 bcrypt.compare(_password, this.password, function (err, isMatch) {
  if (err) {
  return cb(err);
  }
  cb(null, isMatch);
 })
 }
};
UserSchema.statics = {
 fetch: function (cb) {
 return this
  .find({})
  .sort('meta.updateAt')
  .exec(cb);
 },
 findById: function (id, cb) {
 return this
  .findOne({_id: id})
  .exec(cb)
 }
};
module.exports = UserSchema;

model編譯模型

// models/user.js
var mongoose = require('mongoose');
//模式
var UserSchema = require('../schemas/user');
//編譯模型
var User = mongoose.model('user',UserSchema);
module.exports = User;

入口文件注入

//app.js
var User = require('./models/user');
app.set('view engine', 'jade'); // jade模板引擎
app.set("views", "./views/pages/"); // 視圖根目錄
var serveStatic = require('serve-static'); // 靜態(tài)文件處理
app.use(serveStatic('public')); // 路徑:public

身份驗(yàn)證中間件

獲取session的用戶(hù)名,存入到locals中,暴露給視圖使用,即header.jade中可以獲取到user。

app.use(function (req, res, next) {
 var _user = req.session.user;
 app.locals.user = _user;
 return next();
});

看完了這篇文章,相信你對(duì)“Node+Express+MongoDB如何實(shí)現(xiàn)登錄注冊(cè)功能”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

分享文章:Node+Express+MongoDB如何實(shí)現(xiàn)登錄注冊(cè)功能
文章出自:http://jinyejixie.com/article44/pgeche.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)網(wǎng)站維護(hù)、外貿(mào)網(wǎng)站建設(shè)網(wǎng)頁(yè)設(shè)計(jì)公司、云服務(wù)器、網(wǎng)站設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都app開(kāi)發(fā)公司
山东| 凤庆县| 绿春县| 长泰县| 白朗县| 长春市| 岱山县| 弋阳县| 嫩江县| 麻阳| 平谷区| 呼图壁县| 赣州市| 乐安县| 离岛区| 博爱县| 太谷县| 怀集县| 和政县| 闽清县| 广宁县| 甘谷县| 吉水县| 思南县| 建水县| 右玉县| 彰化县| 莫力| 昭苏县| 康保县| 全椒县| 江孜县| 墨玉县| 迭部县| 太白县| 监利县| 上杭县| 五常市| 酉阳| 县级市| 华坪县|