Node.js如何实现注册邮箱激活功能 (常见)


Posted in Javascript onJuly 23, 2017

一. 先注册一个支持发送验证邮件的邮箱,网易的126邮箱就可以

注册成功后进行登录,然后点击导航栏的设置,选择POP3/SMTP/IMAP,开启POP3/SMTP/IMAP服务,设置授权码就可以了。

二. 下载nodemailer插件

在命令行输入:npm install --save nodemailer

三. 编写发送邮件代码:

1 . 对发送激活邮件代码进行封装,然后导出:

//email.js
// 引入 nodemailer
var nodemailer = require('nodemailer');
// 创建一个SMTP客户端配置
var config = {
    host: 'smtp.126.com', 
    port: 25,
    auth: {
      user: 'xxx@126.com', //刚才注册的邮箱账号
      pass: 'xxxxxx' //邮箱的授权码,不是注册时的密码
    }
  };
// 创建一个SMTP客户端对象
var transporter = nodemailer.createTransport(config);
// 发送邮件
module.exports = function (mail){
  transporter.sendMail(mail, function(error, info){
    if(error) {
      return console.log(error);
    }
    console.log('mail sent:', info.response);
  });
};

2 . 进行测试:

//sendtest.js
var send = require('./mail-test');
// 创建一个邮件对象
var mail = {
  // 发件人
  from: '流觞曲水 <xxx@126.com>',
  // 主题
  subject: '测试',
  // 收件人
  to: 'xxx@qq.com',
  // 邮件内容,HTML格式
  text: '点击激活:xxx' //接收激活请求的链接
};
send(mail);

成功就可以在测试的邮箱看到所发的信息。

四. 验证步骤

就我自己之前写的一个个人博客的项目而言,简单的讲一下如何实现邮箱验证。

1 . 在自己定义的数据库用户数据结构中一定要有激活码、过期时间、是否已经激活的字段,用于在激活时进行判断;

{
  code: String, //激活码,格式自己定义
  date: Number, //过期日期,过期后不能激活
  islive: Boolean //判断是否激活
}

2 . 发送激活链接,其中包含用户名和激活码,如下面这样:

// 创建一个邮件对象
  var mail = {
    // 发件人
    from: '小静博客 <xiaojing@126.com>',
    // 主题
    subject: '激活账号',
    // 收件人
    to: usermess.email, //发送给注册时填写的邮箱
    // 邮件内容,HTML格式
    text: '点击激活:<a href="http://localhost:3000/checkCode?name='+ usermess.name +'&code='+ usermess.code + '" rel="external nofollow" ></a>'
  };

3 . 响应激活请求,根据激活链接的用户名进行查找,若用户存在则判断激活码是否一致,并判断激活码是否过期,全部正确则改变激活状态,此时激活成功,如下代码:

exports.checkCode = function (req, res){
  var username = req.query.name;
  var code = req.query.code;
  var outdate = req.query.outdate;
  User.findOne({name: username}, function (err, user){
    if (user.code === code && (user.date - Date.now()) > 0){
      User.update({name: username}, {islive: true}, function (err){
        if (err){
          res.render('login', {
            title: '登录',
            error: '激活失败!'
          });
        }else{
          res.render('login', {
            title: '登录',
            error: '激活成功请登录!'
          });
        }
      });
    }
  });
}

以上所述是小编给大家介绍的Node.js如何实现注册邮箱激活功能 ,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
JQuery获取当前屏幕的高度宽度的实现代码
Jul 12 Javascript
解析John Resig Simple JavaScript Inheritance代码
Dec 03 Javascript
快速查找数组中的某个元素并返回下标示例
Sep 03 Javascript
键盘上一张下一张兼容IE/google/firefox等浏览器
Jan 28 Javascript
js+HTML5实现视频截图的方法
Jun 16 Javascript
设置点击文本框或图片弹出日历控件的实现代码
May 12 Javascript
jquery的ajax提交form表单的两种方法小结(推荐)
May 25 Javascript
Vue.js实现一个SPA登录页面的过程【推荐】
Apr 29 Javascript
JavaScript高阶函数_动力节点Java学院整理
Jun 28 Javascript
微信小程序非swiper组件实现的自定义伪3D轮播图效果示例
Dec 11 Javascript
详解用async/await来处理异步
Aug 28 Javascript
微信小程序 wx:for 与 wx:for-items 与 wx:key的正确用法
May 19 Javascript
jQuery.Ajax()的data参数类型详解
Jul 23 #jQuery
vue axios用法教程详解
Jul 23 #Javascript
bootstrap table插件的分页与checkbox使用详解
Jul 23 #Javascript
关于JavaScript中的this指向问题总结篇
Jul 23 #Javascript
浅析JS中常用类型转换及运算符表达式
Jul 23 #Javascript
js实现带进度条提示的多视频上传功能
Dec 13 #Javascript
基于javaScript的this指向总结
Jul 22 #Javascript
You might like
php将12小时制转换成24小时制的方法
2015/03/31 PHP
详解PHP匿名函数与注意事项
2016/03/29 PHP
PHP简单判断手机设备的方法
2016/08/23 PHP
php上传后台无法收到数据解决方法
2019/10/28 PHP
JavaScript高级程序设计 DOM学习笔记
2011/09/10 Javascript
jQuery去掉字符串起始和结尾的空格(多种方法实现)
2013/04/01 Javascript
Jquery事件的连接使用示例
2013/06/18 Javascript
javascript实现左右控制无缝滚动
2014/12/31 Javascript
详细分析JavaScript函数定义
2015/07/16 Javascript
jQuery实现的简单排序功能示例【冒泡排序】
2017/01/13 Javascript
vue动态路由实现多级嵌套面包屑的思路与方法
2017/08/16 Javascript
Vue中 v-if 和v-else-if页面加载出现闪现的问题及解决方法
2018/10/12 Javascript
详解小程序rich-text对富文本支持方案
2018/11/28 Javascript
解决element-ui的下拉框有值却无法选中的情况
2020/11/07 Javascript
[03:02]2020完美世界城市挑战赛(秋季赛)总决赛回顾
2021/03/11 DOTA
PYTHON正则表达式 re模块使用说明
2011/05/19 Python
python执行使用shell命令方法分享
2017/11/08 Python
Python列表生成式与生成器操作示例
2018/08/01 Python
TensorFlow实现模型评估
2018/09/07 Python
Python基于plotly模块实现的画图操作示例
2019/01/23 Python
详解python3安装pillow后报错没有pillow模块以及没有PIL模块问题解决
2019/04/17 Python
PyQT实现菜单中的复制,全选和清空的功能的方法
2019/06/17 Python
Python利用PyExecJS库执行JS函数的案例分析
2019/12/18 Python
Python基于read(size)方法读取超大文件
2020/03/12 Python
Python-for循环的内部机制
2020/06/12 Python
芝加哥牛排公司:Chicago Steak Company
2018/10/31 全球购物
英国在线药房和在线药剂师:Chemist 4 U
2020/01/05 全球购物
车间班组长的职责
2013/12/13 职场文书
颁奖典礼主持词
2014/03/25 职场文书
经典演讲稿汇总
2014/05/19 职场文书
《中国梦我的梦》小学生演讲稿
2014/08/20 职场文书
党员教师群众路线对照检查材料思想汇报
2014/09/29 职场文书
付款证明模板
2015/06/19 职场文书
六一文艺汇演主持词
2015/06/30 职场文书
2016年中秋节晚会领导致辞
2015/11/26 职场文书
Redis持久化与主从复制的实践
2021/04/27 Redis