今天了解了node如何實(shí)現(xiàn)郵箱激活功能,這個功能非常常見,當(dāng)我們注冊一個賬號時悟衩,肯定會有這步,下面看下如何實(shí)現(xiàn)這個功能栓拜。
一. 先注冊一個支持發(fā)送驗(yàn)證郵件的郵箱座泳,網(wǎng)易的126郵箱就可以
注冊成功后進(jìn)行登錄,然后點(diǎn)擊導(dǎo)航欄的設(shè)置菱属,選擇POP3/SMTP/IMAP钳榨,開啟POP3/SMTP/IMAP服務(wù),設(shè)置授權(quán)碼就可以了纽门。
二. 下載nodemailer插件
在命令行輸入:
npm install --save nodemailer
三. 編寫發(fā)送郵件代碼:
1 . 對發(fā)送激活郵件代碼進(jìn)行封裝薛耻,然后導(dǎo)出:
//email.js
// 引入 nodemailer
var nodemailer = require('nodemailer');
// 創(chuàng)建一個SMTP客戶端配置
var config = {
host: 'smtp.126.com',
port: 25,
auth: {
user: 'xxx@126.com', //剛才注冊的郵箱賬號
pass: 'xxxxxx' //郵箱的授權(quán)碼,不是注冊時的密碼
}
};
// 創(chuàng)建一個SMTP客戶端對象
var transporter = nodemailer.createTransport(config);
// 發(fā)送郵件
module.exports = function (mail){
transporter.sendMail(mail, function(error, info){
if(error) {
return console.log(error);
}
console.log('mail sent:', info.response);
});
};
2 . 進(jìn)行測試:
//sendtest.js
var send = require('./mail-test');
// 創(chuàng)建一個郵件對象
var mail = {
// 發(fā)件人
from: '流觴曲水 <xxx@126.com>',
// 主題
subject: '測試',
// 收件人
to: 'xxx@qq.com',
// 郵件內(nèi)容赏陵,HTML格式
text: '點(diǎn)擊激活:xxx' //接收激活請求的鏈接
};
send(mail);
成功就可以在測試的郵箱看到所發(fā)的信息饼齿。
四. 驗(yàn)證步驟
就我自己之前寫的一個個人博客的項(xiàng)目而言,簡單的講一下如何實(shí)現(xiàn)郵箱驗(yàn)證蝙搔。
1 . 在自己定義的數(shù)據(jù)庫用戶數(shù)據(jù)結(jié)構(gòu)中一定要有激活碼缕溉、過期時間、是否已經(jīng)激活的字段吃型,用于在激活時進(jìn)行判斷证鸥;
{
code: String, //激活碼,格式自己定義
date: Number, //過期日期勤晚,過期后不能激活
islive: Boolean //判斷是否激活
}
2 . 發(fā)送激活鏈接枉层,其中包含用戶名和激活碼,如下面這樣:
// 創(chuàng)建一個郵件對象
var mail = {
// 發(fā)件人
from: '小靜博客 <xiaojing@126.com>',
// 主題
subject: '激活賬號',
// 收件人
to: usermess.email, //發(fā)送給注冊時填寫的郵箱
// 郵件內(nèi)容赐写,HTML格式
text: '點(diǎn)擊激活:<a href="http://localhost:3000/checkCode?name='+ usermess.name +'&code='+ usermess.code + '"></a>'
};
3 . 響應(yīng)激活請求鸟蜡,根據(jù)激活鏈接的用戶名進(jìn)行查找,若用戶存在則判斷激活碼是否一致挺邀,并判斷激活碼是否過期揉忘,全部正確則改變激活狀態(tài),此時激活成功端铛,如下代碼:
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: '激活成功請登錄禾蚕!'
});
}
});
}
});
}
大概步驟就是這樣乳蓄,感興趣的可以嘗試一下!