中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Express + Session如何實現登錄驗證功能

發布時間:2021-05-21 13:50:11 來源:億速云 閱讀:225 作者:小新 欄目:web開發

小編給大家分享一下Express + Session如何實現登錄驗證功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

1. 寫在前面

當我們登錄了一個網站,在沒有退出登錄的情況下,我們關閉了這個網站 ,過一段時間,再次打開這個網站,依然還會是登錄狀態。這是因為,當我們登錄了一個網站,服務器會保存我們的登錄狀態,直到我們退出登錄,或者保存的登錄狀態過期。那服務器是通過什么存儲我們的登錄狀態的呢? 答案就是 Session ,服務通過 Session 能夠記錄每個客戶端連接的狀態。關于 Session 的原理,在這就不多說了,本文主要介紹在 Express 框架中,如何使用 Session 來實現用戶登錄身份驗證。

2. 環境配置

在Node 環境中, 并沒有集成 Express 和 Session 的庫,因此需要進行安裝,首先進入建立一個項目目錄,然后在項目根目錄中,利用下面命令安裝四個模塊。

1) Express

該模塊能夠讓我們快速的搭建一個 Web 開發框架。

2) body-parser

該模塊是 Express 模塊的中間件,方便我們解析瀏覽器發送來的 body 數據。

3) express-session

該模塊也是 Express 模塊中間件,方便我們處理客戶端的 session。

4) ejs

該模塊是一個渲染引擎。 方便我們將后臺變量數據綁定到前臺頁面上。

安裝如下:

npm install express --save
npm install body-parser --save
npm install express-session --save
npm install ejs --save

3. 登錄與驗證

Session 能夠標記客戶端在服務器上的狀態。利用這一點,我們能夠實現客戶端的登錄驗證。Session 登錄驗證的流程大致為:客戶端若在未登錄的狀態下請求主頁,那么服務器將該請求重定向到登錄頁面;客戶端在登錄后,服務器需要記錄保存該客戶端的登錄狀態,并給予一個活動期限,這樣下一次服務器請求主頁的時候,就能夠判斷該客戶端的登錄狀態,若登錄狀態有效,直接返回客戶端需要的頁面,否則重定向到登錄頁面。

對于 Session 的過期時間,如果沒有設置 Session 的過期時間,服務器會根據自己配置中默認有效期,將長期不與服務器交互的 Session 進行刪除。

下面貼出實例代碼,界面比較簡單,服務器后臺代碼注釋寫的很清楚,因此就不再進行說明了。

項目的目錄結構如下:

登錄頁面(login.html) 代碼如下:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
  <style type="text/css">

  </style>
</head>
<body>
  <form action="/login" method="POST">
    用戶名: <input type="text" name="username"/> <br>
    密碼: <input type="password" name="pwd"/>
    <input type="submit" value="Submit"/>
  </form>
</body>
</html>

主頁(home.html)代碼如下:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
  <div>用戶名:<span><%= username %> </span> <a href="/logout" rel="external nofollow" >退出登錄</a></div>
</body>
</html>

服務器(app.js)代碼如下:

/**
 * Created by tjm on 9/7/2017.
 */
var express = require('express');
var app = express();
var session = require('express-session');
var bodyparser = require('body-parser');
// 下面三行設置渲染的引擎模板
app.set('views', __dirname); //設置模板的目錄
app.set('view engine', 'html'); // 設置解析模板文件類型:這里為html文件
app.engine('html', require('ejs').__express); // 使用ejs引擎解析html文件中ejs語法
app.use(bodyparser.json()); // 使用bodyparder中間件,
app.use(bodyparser.urlencoded({ extended: true }));
// 使用 session 中間件
app.use(session({
  secret : 'secret', // 對session id 相關的cookie 進行簽名
  resave : true,
  saveUninitialized: false, // 是否保存未初始化的會話
  cookie : {
    maxAge : 1000 * 60 * 3, // 設置 session 的有效時間,單位毫秒
  },
}));
// 獲取登錄頁面
app.get('/login', function(req, res){
  res.sendFile(__dirname + '/login.html')
});
// 用戶登錄
app.post('/login', function(req, res){
  if(req.body.username == 'admin' && req.body.pwd == 'admin123'){
    req.session.userName = req.body.username; // 登錄成功,設置 session
    res.redirect('/');
  }
  else{
    res.json({ret_code : 1, ret_msg : '賬號或密碼錯誤'});// 若登錄失敗,重定向到登錄頁面
  }
});
// 獲取主頁
app.get('/', function (req, res) {
  if(req.session.userName){ //判斷session 狀態,如果有效,則返回主頁,否則轉到登錄頁面
    res.render('home',{username : req.session.userName});
  }else{
    res.redirect('login');
  }
})
// 退出
app.get('/logout', function (req, res) {
  req.session.userName = null; // 刪除session
  res.redirect('login');
});
app.listen(8000,function () {
  console.log('http://127.0.0.1:8000')
})

到此,session 實現登錄驗證就完成。上面的例子 session 是保存在服務內存中,當然還可以保存在文件或數據庫中,只需要配置 session 中間件即可。

app.use(session({
  secret: 'secretkey',
  store: new MongoStore({
    db: 'sessiondb'
  })
}));

以上是“Express + Session如何實現登錄驗證功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

德惠市| 泗阳县| 扶沟县| 灵台县| 榆社县| 涞水县| 巧家县| 会泽县| 宁陵县| 象山县| 定边县| 莱阳市| 陈巴尔虎旗| 巧家县| 泗洪县| 钦州市| 广西| 根河市| 望城县| 西藏| 平原县| 海南省| 蓝田县| 和林格尔县| 三门峡市| 绵竹市| 秦安县| 玉门市| 泸水县| 吴旗县| 德保县| 东海县| 乌鲁木齐市| 布尔津县| 正安县| 册亨县| 姜堰市| 化隆| 宝应县| 乌鲁木齐市| 泸州市|