自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

前端工程師如何使用Nodejs自動發(fā)送郵件?

開發(fā) 前端
之前用Nodejs做了很多服務端模塊, 最近抽空復盤一下, 接下來筆者將介紹如何使用Nodejs來自動向用戶發(fā)送郵件.

 筆者將詳細介紹自動發(fā)送郵箱的實現(xiàn)方案, 以及通過一個實際的案例來帶大家掌握使用nodejs自動發(fā)送郵件, 最后會介紹一些實際的應用場景, 來加深對該方案的理解, 達到學以致用的目的。

實現(xiàn)方案

實現(xiàn)自動發(fā)送郵件筆者采用了基于Nodejs生態(tài)的nodemailer, 它可以輕松的幫我們發(fā)送電子郵件, 官網(wǎng)地址: nodemailer.

 

前端工程師如何使用nodejs自動發(fā)送郵件?

 

之所以選擇nodemailer是因為它提供了非常靈活的自定義配置和安全保障, 比如:

  • 具有零依賴關系的單一模塊, 代碼容易審核,沒有死角
  • Unicode支持使用任何字符,包括表情符號
  • 郵件內(nèi)容既支持普通文本, 還支持自定義html
  • 支持自定義附件
  • 支持安全可靠的SSL/STARTTLS郵件發(fā)送
  • 支持自定義插件處理郵件消息

還有很多特點筆者就不一一介紹了. 接下來我們來看一個筆者簡化并翻譯的官網(wǎng)案例:

  1. "use strict";  
  2. const nodemailer = require("nodemailer");  
  3.   
  4. // 使用async..await 創(chuàng)建執(zhí)行函數(shù)  
  5. async function main() {  
  6.   // 如果你沒有一個真實郵箱的話可以使用該方法創(chuàng)建一個測試郵箱  
  7.   let testAccount = await nodemailer.createTestAccount();  
  8.   
  9.   // 創(chuàng)建Nodemailer傳輸器 SMTP 或者 其他 運輸機制  
  10.   let transporter = nodemailer.createTransport({  
  11.     host: "smtp.ethereal.email", // 第三方郵箱的主機地址  
  12.     port: 587,  
  13.     secure: false, // true for 465, false for other ports  
  14.     auth: {  
  15.       user: testAccount.user, // 發(fā)送方郵箱的賬號  
  16.       pass: testAccount.pass, // 郵箱授權密碼  
  17.     },  
  18.   });  
  19.   
  20.   // 定義transport對象并發(fā)送郵件  
  21.   let info = await transporter.sendMail({  
  22.     from'"Dooring  " <dooring2021@163.com>', // 發(fā)送方郵箱的賬號  
  23.     to"bar@example.com, baz@example.com", // 郵箱接受者的賬號  
  24.     subject: "Hello Dooring", // Subject line  
  25.     text: "H5-Dooring?", // 文本內(nèi)容  
  26.     html: "歡迎注冊h5.dooring.cn, 您的郵箱驗證碼是:<b>${emailCode}</b>", // html 內(nèi)容, 如果設置了html內(nèi)容, 將忽略text內(nèi)容  
  27.   });  
  28. }  
  29.   
  30. main().catch(console.error);  

以上代碼是發(fā)送帶有純文本和HTML正文的電子郵件的完整示例. 筆者在代碼上做了詳細的翻譯, 我們可以總結出要想發(fā)送郵件, 我們需要如下3個步驟:

  • 創(chuàng)建Nodemailer傳輸器 SMTP 或者其他運輸機制
  • 設置 Message 選項(將什么消息發(fā)送給誰)
  • 使用先前創(chuàng)建的傳輸器的sendMail()方法傳遞消息對象

宏觀的使用流程我們知道了, 接下來我們落實到每一個技術功能點來實現(xiàn).我們需要關注如下幾個核心點:

  • 如何設置 host
  • 如何設置 auth
  • 如何配置 Message 選項

解答了以上3個問題, 我們就能靈活的使用Nodemailer發(fā)送自定義郵件了.

如何設置host, port, secure

這里筆者拿網(wǎng)易郵箱來舉例. 比如我們想用我們自己的網(wǎng)易郵箱給用戶發(fā)送郵件, 我們需要先注冊一個用于發(fā)送郵件的網(wǎng)易郵箱, 比如dooring2021@163.com. 由于我們采用SMTP傳輸器 , 所以在郵箱主頁我們找到如下選項并設置:

 

前端工程師如何使用nodejs自動發(fā)送郵件?

在該頁面下方我們可以找到對應的host, 如下:

 

前端工程師如何使用nodejs自動發(fā)送郵件?

 

關于port和secure, 我們采用默認配置即可, 設置secure為true,表示端口默認使用465. 詳細配置如下:

 

前端工程師如何使用nodejs自動發(fā)送郵件?

 

如何設置auth

auth我們在上一步的操作中已經(jīng)涉及到了, 我們在開啟IMAP/SMTP服務時會提示保存郵箱授權碼, 這里的授權碼就是auth.pass的值, auth.user表示當前授權的郵箱.

如何設置Message

消息配置是我們郵箱服務比較重要的部分, 官方提供了如下幾個配置說明:

 

 

這里筆者給大家詳細介紹一下:

  • from 發(fā)件人的電子郵件地址。所有電子郵件地址都可以是純'sender@server.com“或格式化”‘發(fā)送者名稱’sender@server.com'
  • to 逗號分隔的列表或收件人的電子郵件地址的排列
  • cc 逗號分隔的列表或?qū)@示在“抄送”字段中的收件人電子郵件地址數(shù)組
  • bcc 逗號分隔的列表或?qū)@示在“密件抄送:”字段中的收件人電子郵件地址數(shù)組
  • subject 電子郵件的主題
  • text 消息的文本內(nèi)容
  • html 消息的html內(nèi)容, 如果定義了html, 將忽略text
  • attachments 附件內(nèi)容

熟悉了以上配置之后我們基本可以配置滿足80%場景的郵件發(fā)送需求了. 這里我們來看一個設置Message的簡單案例:

  1. await transporter.sendMail({  
  2.   from'"v6.dooring" <dooring2021@163.com>', // sender address  
  3.   to'xujiang156@qq.com', // list of receivers  
  4.   subject: 'welcome to use dooring', // Subject line  
  5.   text: 'Hello world?', // plain text body  
  6.   html: `歡迎注冊v6.dooring, 您的郵箱驗證碼是:<b>${emailCode}</b>`, // html body  
  7. })  

 

該案例是使用dooring郵箱給一個普通用戶發(fā)送郵箱驗證碼的場景, 是不是很熟悉呢? 這個場景目前被應用在很多登錄注冊相關的場景中. 接下來看看實際的效果:

 

 

擴展

我們利用Nodemailer可以開發(fā)很多有意思的產(chǎn)品, 比如: - 在線郵箱客戶端 - 定制郵箱模版 - 郵箱驗證中樞系統(tǒng) - 郵箱群發(fā)助手

等等. 關于第二個應用場景, 目前開源有很多漂亮的郵箱模版, 比如 - Foundation for Emails - emailframe http://emailframe.work - MJML https://mjml.io

 

前端工程師如何使用nodejs自動發(fā)送郵件?

 

最后

目前筆者也在持續(xù)更新H5編輯器 H5-Dooring, 以及可視化大屏編輯器V6.Dooring,近期更新如下:

  • 修復圖片庫選擇bug
  • 添加省市級聯(lián)組件
  • 添加批量導入 excel 數(shù)據(jù)的能力
  • 添加表單自定義校驗
  • 音頻組件添加自動播放控制, 循環(huán)播放等配置項
  • 添加橫向滑動組件

 

責任編輯:華軒 來源: 今日頭條
相關推薦

2021-02-18 07:20:51

Nodejs前端開發(fā)

2023-12-06 11:10:08

2016-09-22 16:14:45

前端設計Photoshop

2012-06-28 14:23:32

Web

2015-08-26 14:18:25

Web前端工程師價值

2015-09-30 10:37:31

前端工程師閑余時光

2019-03-14 11:02:21

Serverless前端工程師Ajax

2015-09-30 10:25:03

前端工程師

2010-01-13 10:10:07

Web前端工程師

2015-03-16 16:01:40

Web前端前端工程師Web

2018-11-15 15:55:44

前端工程師Web云計算

2010-01-13 10:53:51

Web前端工程師定位

2019-07-29 16:05:48

前端DockerNode.js

2016-01-28 11:18:09

卓越前端工程師

2015-08-17 10:32:06

前端工程師優(yōu)秀

2015-08-24 09:02:49

前端工程師

2014-12-23 14:55:23

前端

2019-06-24 09:40:17

前端前端工程師開發(fā)工具

2011-05-25 16:59:20

前端工程師

2020-07-27 16:52:59

Mailmerge定制郵件系統(tǒng)應用
點贊
收藏

51CTO技術棧公眾號