Express + Session 实现登录验证功能


Posted in Javascript onSeptember 08, 2017

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'
  })
}));

上面的代码则是将 session 保存到 MongoDB 数据库,当然 Session 的配置还有一些,具体参考:

https://www.npmjs.com/package/express-session

总结

以上所述是小编给大家介绍的Express + Session 实现登录验证功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Jquery getJSON方法详细分析
Dec 26 Javascript
ZeroClipboard插件实现多浏览器复制功能(支持firefox、chrome、ie6)
Aug 30 Javascript
深入理解JavaScript系列(45):代码复用模式(避免篇)详解
Mar 04 Javascript
基于javascript实现tab选项卡切换特效调试笔记
Mar 30 Javascript
Websocket协议详解及简单实例代码
Dec 12 Javascript
详解angular2封装material2对话框组件
Mar 03 Javascript
关于vue.js发布后路径引用的问题解决
Aug 15 Javascript
基于打包工具Webpack进行项目开发实例
May 29 Javascript
操作按钮悬浮固定在微信小程序底部的实现代码
Aug 02 Javascript
vue实现权限控制路由(vue-router 动态添加路由)
Nov 04 Javascript
js回调函数仿360开机
Dec 26 Javascript
JS+CSS实现过渡特效
Jan 02 Javascript
Vue中组件之间数据的传递的示例代码
Sep 08 #Javascript
详解jquery插件jquery.viewport.js学习使用方法
Sep 08 #jQuery
JavaScript实现开关等效果
Sep 08 #Javascript
浅谈React Native 中组件的生命周期
Sep 08 #Javascript
Vue仿手机qq的实例代码(demo)
Sep 08 #Javascript
关于Ajax的原理以及代码封装详解
Sep 08 #Javascript
vue父子组件的嵌套的示例代码
Sep 08 #Javascript
You might like
php下实现农历日历的代码
2007/03/07 PHP
php桌面中心(三) 修改数据库
2007/03/11 PHP
PHP url 加密解密函数代码
2011/08/26 PHP
phpadmin如何导入导出大数据文件及php.ini参数修改
2013/02/18 PHP
解析php php_openssl.dll的作用
2013/07/01 PHP
jQuery EasyUI API 中文文档 可调整尺寸
2011/09/29 Javascript
回车直接实现点击某按钮的效果即触发单击事件
2014/02/27 Javascript
javascript类型系统 Array对象学习笔记
2016/01/09 Javascript
基于javascript实现按圆形排列DIV元素(三)
2016/12/02 Javascript
js 中文汉字转Unicode、Unicode转中文汉字、ASCII转换Unicode、Unicode转换ASCII、中文转换
2016/12/06 Javascript
JavaScript使用原型和原型链实现对象继承的方法详解
2017/04/05 Javascript
深入理解react-router@4.0 使用和源码解析
2017/05/23 Javascript
JavaScript定义函数_动力节点Java学院整理
2017/06/27 Javascript
javascript实现电脑和手机版样式切换
2017/11/10 Javascript
使用Vue-cli 3.0搭建Vue项目的方法
2018/06/07 Javascript
使用Python解析JSON数据的基本方法
2015/10/15 Python
Python 数据处理库 pandas 入门教程基本操作
2018/04/19 Python
Python实现的括号匹配判断功能示例
2018/08/25 Python
python调用百度语音REST API
2018/08/30 Python
Python流行ORM框架sqlalchemy安装与使用教程
2019/06/04 Python
Django REST framework 视图和路由详解
2019/07/19 Python
python爬虫刷访问量 2019 7月
2019/08/01 Python
Python HTMLTestRunner测试报告view按钮失效解决方案
2020/05/25 Python
详解torch.Tensor的4种乘法
2020/09/03 Python
python实现AHP算法的方法实例(层次分析法)
2020/09/09 Python
多视角3D可旋转的HTML5 Logo动画
2016/03/02 HTML / CSS
HTML5本地存储之Web Storage详解
2016/07/04 HTML / CSS
Mio Skincare中文官网:肌肤和身体护理
2016/10/26 全球购物
印度尼西亚手表和包包商店:Urban Icon
2019/12/12 全球购物
毕业生自荐信
2013/12/14 职场文书
学生未请假就回家检讨书
2014/09/22 职场文书
先进学校事迹材料
2014/12/30 职场文书
公司开业致辞
2015/07/29 职场文书
2016年大学生党员公开承诺书
2016/03/24 职场文书
Pyhton模块和包相关知识总结
2021/05/12 Python
Python 视频画质增强
2022/04/28 Python