Maison > interface Web > js tutoriel > Node.js implémente l'exemple de processus d'enregistrement de l'activation du courrier électronique

Node.js implémente l'exemple de processus d'enregistrement de l'activation du courrier électronique

零下一度
Libérer: 2017-07-24 15:38:34
original
1622 Les gens l'ont consulté

Aujourd'hui, j'ai appris comment node implémente la fonction d'activation par e-mail. Cette fonction est très courante lorsque nous enregistrons un compte, nous aurons certainement cette étape. Voyons comment implémenter cette fonction

<.> 1. Enregistrez d'abord une adresse e-mail prenant en charge l'envoi d'e-mails de vérification. L'adresse e-mail 126 de NetEase peut être utilisée

Connectez-vous après une inscription réussie, puis cliquez sur les paramètres dans le

colonne de navigation et sélectionnez POP3/SMTP/IMAP, activez le service POP3/SMTP/IMAP et définissez le code d'autorisation.

2. Téléchargez le plug-in nodemailer

Saisissez sur la ligne de commande :

npm install --save nodemailer

3 . Écrivez le code pour envoyer l'e-mail :

1 . Encapsulez le code pour envoyer l'e-mail d'activation et exportez-le :

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


//sendtest.js
var send = require(&#39;./mail-test&#39;);
// 创建一个邮件对象
var mail = {
  // 发件人
  from: &#39;流觞曲水 <xxx@126.com>&#39;,
  // 主题
  subject: &#39;测试&#39;,
  // 收件人
  to: &#39;xxx@qq.com&#39;,
  // 邮件内容,HTML格式
  text: &#39;点击激活:xxx&#39; //接收激活请求的链接
};
send(mail);
Copier après la connexion
En cas de succès, vous pouvez voir le message envoyé dans la boîte aux lettres de test.

Quatre étapes de vérification

En ce qui concerne un projet de blog personnel que j'ai écrit auparavant, je parlerai brièvement de la façon de le mettre en œuvre

Vérification par e-mail.

1. Dans la structure des données utilisateur de la base de données que vous définissez, il doit y avoir des champs tels que le code d'activation, l'heure d'expiration et s'il a été activé, qui sont utilisés pour juger lors de l'activation


{
  code: String, //激活码,格式自己定义
  date: Number, //过期日期,过期后不能激活
  islive: Boolean //判断是否激活
}
Copier après la connexion
2. Envoyez le lien d'activation, qui contient le nom d'utilisateur et le code d'activation, comme suit :


// 创建一个邮件对象
  var mail = {
    // 发件人
    from: &#39;小静博客 <xiaojing@126.com>&#39;,
    // 主题
    subject: &#39;激活账号&#39;,
    // 收件人
    to: usermess.email, //发送给注册时填写的邮箱
    // 邮件内容,HTML格式
    text: &#39;点击激活:<a href="localhost:3000/checkCode?name=&#39;+ usermess.name +&#39;&code=&#39;+ usermess.code + &#39;" rel="external nofollow" ></a>&#39;
  };
Copier après la connexion
3. Répondez à la demande d'activation, selon Rechercher le nom d'utilisateur du lien d'activation. Si l'utilisateur existe, déterminez si le code d'activation est cohérent et déterminez si le code d'activation a expiré. Si tous sont corrects, modifiez le statut d'activation. fois, l'activation est réussie, comme indiqué dans le code suivant :


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal