欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

express框架下使用session的方法

 更新時間:2019年07月31日 09:28:22   作者:飛機  
這篇文章主要介紹了express框架下使用session的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

上一遍文章說了cookie的不足,提到使用session是解決缺點的一個方法。這遍文章說說怎么使用session.作者使用了文件保存session的方法。若用別保存方式(內(nèi)存、數(shù)據(jù)庫)也行,記得使用相應的模塊。
下面從使用內(nèi)存存儲和文件存儲的2個方法分別說明。

內(nèi)存存儲session

實現(xiàn)過程

// app.js
// 引入express-session
var session = require('express-session')
// 為應用綁定session中間件
app.use(session({
  name: 'session-id',
  secret: '12345-67890',
  saveUninitialized: false,
  resave: false
}))

查看結果

router.get('/session/first', (req, res, next) => {
 let s = req.session
 console.log(s)
 res.send(s)
})

使用

使用這個方法做一個demo.比如顯示瀏覽次數(shù)。

router.get('/session/view', (req, res, next) => {
 let s = req.session
 if (req.session.views) {
  req.session.views++
  res.send(`views: ${req.session.views} time.`)
 } else {
  req.session.views = 1
  res.send('views: 0')
 }
})


我發(fā)現(xiàn)在操作session后,會在根目錄下創(chuàng)建一個session目錄,里面保存了session.

文件存儲session

相對于內(nèi)存存儲session不同在于保存session的位置不同。內(nèi)存存儲方式是把session保存在session里。對于后臺服務會占用大量內(nèi)存,這種方法肯定不行。文件存儲方式是把session保存在文件夾里。聽說還有一種叫數(shù)據(jù)庫保存。

install

要使用文件存儲session需要安裝session-file-store。

npm i express-session session-file-store

使用文件存儲

// app.js
var session = require('express-session')
var FileStore = require('session-file-store')(session) // 引入 
// 在express-session中使用
app.use(session({
 name: 'session-id',
 secret: '12345-67890',
 saveUninitialized: false,
 resave: false,
 store: new FileStore() // 指明使用文件存儲
}))

注冊、登錄、登錄驗證和登出

這部分需要bodyParser mongoose模塊。記得安裝。

1. 創(chuàng)建數(shù)據(jù)庫連接。

連接了數(shù)據(jù)庫就可以把用戶數(shù)據(jù)放在數(shù)據(jù)庫里。

// app.js
const mongoose = require('mongoose')
const url = 'mongoodb://localhost:27017/confusion'
const connect = mongoose.connect(url, {useNewUrlParser: true, useCreateIndex: true})
connest.then(db => {
 console.log('Connect correct to server')
}, err => {console.log(err)})

2. 創(chuàng)建user的model,用于連接數(shù)據(jù)庫。

在項目根目錄下創(chuàng)建models目錄,再創(chuàng)建user.js。下面定義了user的model

// @/models/user.js
var mongoose = require('mongoose'),
Schema = mongoose.Schema,
User = new Schema({
 username: {
  type: String,
  required: true,
  unique: true
 },
 password: {
  type: String,
  required: true
 },
 admin: {
  type: Boolean,
  default: false
 }
})
module.exports = mongoose.model('User', User)

3. 創(chuàng)建注冊的接口。

注冊的接口
  是否已經(jīng)存在用戶------存在------>不重復創(chuàng)建. 
      |-----------不存在----->創(chuàng)建用戶

// @/routes/users.js
// /session/first /session/view 注釋了或刪除了。
// 該文件在app.user(session(...))之前,所以得不到req.session
// // 查看session
// router.get('/session/first', (req, res, next) => {
//  let s = req.session
//  console.log(s)
//  res.send(s)
// })
// // 在session里保存瀏覽次數(shù)
// router.get('/session/view', (req, res, next) => {
//  let s = req.session
//  if (req.session.views) {
//   req.session.views++
//   res.send(`views: ${req.session.views} time.`)
//  } else {
//   req.session.views = 1
//   res.send('views: 1')
//  }
// })

router.post('/signup', (req, res, next) => {
 console.log(req.body)
 User.findOne({username: req.body.username}).then(user => {
  if (user === null) {
   return User.create({
    username: req.body.username,
    password: req.body.password
   })
  } else {
   var err = new Error(`User ${req.body.username} already exist!`)
   err.status = 403
   next(err)
  }
 }).then(user => {
  res.statusCode = 200
  res.json({status: 'registration successful', user: user})
 }).catch(err => {
  res.send(err)
 })
})

4. 創(chuàng)建登錄的接口。

登錄的接口https://github.com/feigebaobei/nodejs/tree/master/node-session
  是否已經(jīng)登錄------登錄------>不做事 
    |-----------沒登錄----->驗證username/password是否正確.----正確---->設置已經(jīng)登錄 
                    |----------------------不正確---->返回錯誤

router.post('/login', (req, res, next) => {
 if (req.session.auth) { // 以req.session.auth為標記,標記是否已經(jīng)通過登錄驗證
  res.statusCode = 200
  res.send('You are already authenticated')
 } else {
  User.findOne({username: req.body.username}).then(user => {
   if (user) {
    if (user.password !== req.body.password) {
     var err = new Error(`password error`)
     err.status = 403
     next(err)
    } else {
     req.session.auth = true // 登錄成功設置標記為true
     res.statusCode = 200
     res.send('login successful')
    }
   } else { // 沒用指定用戶
    var err = new Error(`User ${req.body.username} does not exist!`)
    err.status = 403
    next(err)
   }
  // }).catch(err => next(err))
  }).catch(err => {
   res.send(err)
  })
 }
})

5. 創(chuàng)建登出的接口。

router.get('/logout', (req, res, next) => {
 if (req.session) {
  req.session.destroy() // 刪除session
  res.clearCookie('session-id') // 刪除cookie
  res.send('登出成功。重定向的事讓前端做')
 } else {
  var err = new Error('you are not logged in!')
  err.status = 403
  next(err)
 }
})

6. 登錄后才可訪問的接口

// @/routes/news.js
var express = require('express');
var router = express.Router();
/* GET home page. */
router.get('/', function(req, res, next) {
 res.render('index', { title: 'Express' });
});
module.exports = router;

7. 編寫登錄驗證的中間件。注意登錄接口、登錄驗證中間件、登錄后才可訪問的接口的次序。

// app.js
// 1.引入路由
var index = require('./routes/index');
var users = require('./routes/users');
var news = require('./routes/news');
// 2.掛載session中間件
app.use(session({
 name: 'session-id',
 secret: '12345-67890',
 saveUninitialized: false,
 resave: false,
 store: new FileStore()
}))
// 3.掛載不需要登錄驗證的路由
app.use('/', index)
app.use('/users', users)
// 4.定義驗證登錄函數(shù)
let authFn = (req, res, next) => {
 console.log(req.session)
 if (req.session.auth) {
  next()
 } else {
  var err = new Error('You are not authenticated!')
  err.status = 403
  next(err)
 }
}
// 5.掛載需要登錄驗證的路由
app.use('/news', news)

總結

這個例子只詮釋了簡單的登錄、驗證登錄、登出功能。下面是本文用到的js模塊(express-session, session-file-store, mongoose)在npm上都能找到。完整代碼

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • node.js中的fs.readdirSync方法使用說明

    node.js中的fs.readdirSync方法使用說明

    這篇文章主要介紹了node.js中的fs.readdirSync方法使用說明,本文介紹了fs.readdirSync方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • node將geojson轉shp返回給前端的實現(xiàn)方法

    node將geojson轉shp返回給前端的實現(xiàn)方法

    這篇文章主要介紹了node將geojson轉shp返回給前端的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • IDEA中配置運行node.js的完整過程

    IDEA中配置運行node.js的完整過程

    為了使在終端使用npm,我們可以配置環(huán)境變量,這篇文章主要給大家介紹了關于IDEA中配置運行node.js的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-10-10
  • Node.js 去掉種子(torrent)文件里的邪惡信息

    Node.js 去掉種子(torrent)文件里的邪惡信息

    torrent文件,又被稱為種子,原來只是用于記錄 bt下載當中所需信息的一種文件。但是隨著互聯(lián)網(wǎng)的極大發(fā)展,一些人士將一些邪惡的信息注入到了小小的 torrent文件當中,種子從此變成了邪惡的代名詞。
    2015-03-03
  • 理解nodejs的stream和pipe機制的原理和實現(xiàn)

    理解nodejs的stream和pipe機制的原理和實現(xiàn)

    本篇文章主要介紹了理解nodejs的stream和pipe機制的原理和實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Node.JS枚舉統(tǒng)計當前文件夾和子目錄下所有代碼文件行數(shù)

    Node.JS枚舉統(tǒng)計當前文件夾和子目錄下所有代碼文件行數(shù)

    這篇文章主要介紹了Node.JS枚舉統(tǒng)計當前文件夾和子目錄下所有代碼文件行數(shù),本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • 關于node編寫文件上傳的接口的坑及解決

    關于node編寫文件上傳的接口的坑及解決

    這篇文章主要介紹了關于node編寫文件上傳的接口的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • nodejs 提示‘xxx’ 不是內(nèi)部或外部命令解決方法

    nodejs 提示‘xxx’ 不是內(nèi)部或外部命令解決方法

    本文介紹了node.js包管理工具npm安裝模塊后,無法通過命令行執(zhí)行命令,提示‘xxx’ 不是內(nèi)部或外部命令的解決方法,給需要的小伙伴參考下。
    2014-11-11
  • node.js基于dgram數(shù)據(jù)報模塊創(chuàng)建UDP服務器和客戶端操作示例

    node.js基于dgram數(shù)據(jù)報模塊創(chuàng)建UDP服務器和客戶端操作示例

    這篇文章主要介紹了node.js基于dgram數(shù)據(jù)報模塊創(chuàng)建UDP服務器和客戶端操作,結合實例形式分析了node.js使用dgram數(shù)據(jù)報模塊創(chuàng)建UDP服務器和客戶端,以及進行UDP廣播、組播相關操作技巧,需要的朋友可以參考下
    2020-02-02
  • Npm link的作用與使用示例代碼

    Npm link的作用與使用示例代碼

    npm link可以幫助我們模擬包安裝后的狀態(tài),它會在系統(tǒng)中做一個快捷方式映射,讓本地的包就好像 install 過一樣,可以直接使用,這篇文章主要介紹了Npm link的作用與使用示例代碼,需要的朋友可以參考下
    2023-01-01

最新評論