nodejs实现用户登录路由功能


Posted in NodeJs onMay 22, 2019

经过前面几次的学习,已经可以做下小功能,今天要实现的事用户登录路由。

一、users_model.js  功能:定义用户对象模型

var mongoose=require('mongoose'),
   Schema=mongoose.Schema;
var UserSchema=new Schema({
   username:{type:String,unique:true},
   email:String,
   color:String,
   hashed_password:String
});
mongoose.model('User',UserSchema);

二、users_controller.js  功能:为Express服务器实现用户登录路由

var crypto=require('crypto');
var mongoose=require('mongoose'),User=mongoose.model('User');
function hashPW(pwd){
  return crypto.createHash('sha256').update(pwd).
  digest('base64').toString();
}
//实现用户登录路由
exports.login=function (req,res){
  User.findOne({username:req.body.username})
  .exec(function(err,user){
    if(!user){
      err='User Not Found';
    }else if(user.hashed_password===hashPW(req.body.password.toString())){
      req.session.regenerate(function(){
        req.session.user=user.id;
        req.session.username=user.username;
        req.session.msg='Authenticated as ' +user.username;
        res.redirect('/');
      });
    }else{
      err='Authentication failed. ';
    }
    if(err){
      req.session.regenerate(function(){
        req.session.msg=err;
        res.redirect('/login');
      });
    }
  });
};

三、login.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>用户登录</title>
<link rel="stylesheet"type="text/css" href="/static/css/styles.css" rel="external nofollow" />
</head>
<body>
<div class="form-container">
 <p class="form-header">登录</p>
 <form method="POST" >
  <label>用户名:</label>
   <input type="text" name="username"><br>
   <label>密码:</label>
   <input type="password" name="password"><br>
   <input type="submit" value="登录">
 </form>
 </div>
 <a href="/signup" rel="external nofollow" >注册</a>
 <hr> <%=msg %>
</body>
</html>

四、routes.js 功能:为Express服务器实现处理Web请求路由

var crypto=require('crypto');
var express=require('express');
module.exports=function(app){
  var users=require('./controllers/users_controller');
  app.use('/static',express.static('./static')).
  use('/lib',express.static('../lib')
);
app.get('/login',function(req,res){
  if(req.session.user){
    res.redirect('/');
  }
  res.render('login',{msg:req.session.msg})
});
app.post('/login',users.login);

页面效果

nodejs实现用户登录路由功能

总结

以上所述是小编给大家介绍的nodejs中实现用户登录路由功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

NodeJs 相关文章推荐
使用Nodejs开发微信公众号后台服务实例
Sep 03 NodeJs
Nodejs异步回调的优雅处理方法
Sep 25 NodeJs
Nodejs极简入门教程(三):进程
Oct 27 NodeJs
NodeJS创建基础应用并应用模板引擎
Apr 12 NodeJs
Nodejs下DNS缓存问题浅析
Nov 16 NodeJs
使用 NodeJS+Express 开发服务端的简单介绍
Apr 07 NodeJs
详解nodejs异步I/O和事件循环
Jun 07 NodeJs
详解nodeJs文件系统(fs)与流(stream)
Jan 24 NodeJs
解决nodejs的npm命令无反应的问题
May 17 NodeJs
NodeJS实现自定义流的方法
Aug 01 NodeJs
NodeJS开发人员常见五个错误理解
Oct 14 NodeJs
node快速搭建后台的实现步骤
Feb 18 NodeJs
基于nodejs的微信JS-SDK简单应用实现
May 21 #NodeJs
nodejs中实现用户注册路由功能
May 20 #NodeJs
nodejs实现日志读取、日志查找及日志刷新的方法分析
May 20 #NodeJs
NodeJS读取分析Nginx错误日志的方法
May 14 #NodeJs
nodejs搭建本地服务器并访问文件操作示例
May 11 #NodeJs
M2实现Nodejs项目自动部署的方法步骤
May 05 #NodeJs
nodejs通过钉钉群机器人推送消息的实现代码
May 05 #NodeJs
You might like
一个多文件上传的例子(原创)
2006/10/09 PHP
PHP字符编码问题之GB2312 VS UTF-8解决方法
2011/06/23 PHP
PHP中echo和print的区别
2014/08/28 PHP
PHP实现图片旋转效果实例代码
2014/10/01 PHP
yii2.0使用Plupload实现带缩放功能的多图上传
2015/12/22 PHP
PHP搭建大文件切割分块上传功能示例
2017/01/04 PHP
ZendFramework2连接数据库操作实例
2017/04/18 PHP
php readfile()修改文件上传大小设置
2017/08/11 PHP
javascript iframe中打开文件,并检测iframe存在否
2008/12/28 Javascript
jQuery判断checkbox是否选中的小例子
2013/12/02 Javascript
javascript检查浏览器是否支持flash的实现代码
2014/08/14 Javascript
javascript实现图像循环明暗变化的方法
2015/02/25 Javascript
纯CSS3代码实现滑动开关效果
2015/08/19 Javascript
webpack配置导致字体图标无法显示的解决方法
2018/03/06 Javascript
Angular2进阶之如何避免Dom误区
2018/04/02 Javascript
Vue.js单向绑定和双向绑定实例分析
2018/08/14 Javascript
使用layui 渲染table数据表格的实例代码
2018/08/19 Javascript
[01:12:35]Spirit vs Navi Supermajor小组赛 A组败者组第一轮 BO3 第二场 6.2
2018/06/03 DOTA
pygame播放音乐的方法
2015/05/19 Python
TensorFlow搭建神经网络最佳实践
2018/03/09 Python
pyspark操作MongoDB的方法步骤
2019/01/04 Python
Python实现的登录验证系统完整案例【基于搭建的MVC框架】
2019/04/12 Python
解决Mac下使用python的坑
2019/08/13 Python
python 实现一个简单的线性回归案例
2020/12/17 Python
浅谈HTML5 Web Worker的使用
2018/01/05 HTML / CSS
公司庆典邀请函范文
2014/01/13 职场文书
成龙霸王洗发水广告词
2014/03/14 职场文书
新年主持词
2014/03/27 职场文书
会计专业自荐书
2014/07/08 职场文书
民主评议党员总结
2014/10/20 职场文书
有限责任公司股东合作协议书范本
2014/10/30 职场文书
2014年幼儿园德育工作总结
2014/12/17 职场文书
2015年公务员工作总结
2015/04/24 职场文书
幼儿园安全教育随笔
2015/08/14 职场文书
Python Django框架介绍之模板标签及模板的继承
2021/05/27 Python
Java GUI编程菜单组件实例详解
2022/04/07 Java/Android