首页 > 编程语言 >node.js使用Nodemailer发送邮件

node.js使用Nodemailer发送邮件

时间:2023-04-20 17:13:15浏览次数:59  
标签:node qq const Nodemailer js mail 邮箱 com nodemailer

引言

--
常常看到一些网站有邮箱获取验证码验证注册或者修改密码等,今天也来了解一下在nodejs + express怎么发送电子邮件。使用模块Nodemailer。这里以qq邮箱举例子。

安装模块

--
npm install Nodemailer --save

创建一个SMTP客户端配置

--

//引入模块 nodemailer
 const nodemailer = require('nodemailer')

 const config = {
    // 163邮箱 为smtp.163.com
    host: 'smtp.qq.com',//这是qq邮箱
    //端口
    port: 465,
    auth: {
        // 发件人邮箱账号
        user: '[email protected]', 
        //发件人邮箱的授权码 这里可以通过qq邮箱获取 并且不唯一
        pass: 'xxxxxxxxx'  
    }
 }
# 创建一个SMTP客户端配置对象
--
即把上述的客户端配置作为nodemailer.createTransport方法参数传递进去即可

`const transporter = nodemailer.createTransport(config)`
# 创建一个收件人对象
即填写发件人和收件人的一些信息,以及发送的内容

const mail = {
// 发件人 邮箱 '昵称<发件人邮箱>'
from: '车神-黄杰[email protected]',
// 主题
subject: '激活验证码',
// 收件人 的邮箱 可以是其他邮箱 不一定是qq邮箱
to: 'xxxxxx',
// 内容
text: 您的激活验证码为:666888, 请24小时内有效,请谨慎保管。 ,
//这里可以添加html标签
html: '车神-黄杰'
}

# 发送邮件 调用 transporter.sendMail(mail, callback)
--
@params mail 收件人配置对象
@params callback 回调函数

function sendEmail(mail){
transporter.sendMail(mail, function(error, info){
if(error) {
return console.log(error);
}
transporter.close()
console.log('mail sent:', info.response)
})
}

# 获取授权码
打开pc端qq邮箱,点击设置,再点击帐户

![](/i/l/?n=23&i=blog/2653936/202304/2653936-20230420170625986-148176959.png)

往下拉 可开启POP3/SMTP服务 根据提示即可获取qq邮箱授权码

![](/i/l/?n=23&i=blog/2653936/202304/2653936-20230420170643285-1004237851.png)


# 完整代码
我把这些代码封装成一个nodemailer.js文件

//引入模块 nodemailer
const nodemailer = require('nodemailer')

const config = {
// 163邮箱 为smtp.163.com
host: 'smtp.qq.com',//这是qq邮箱
//端口
port: 465,
auth: {
// 发件人邮箱账号
user: '[email protected]',
//发件人邮箱的授权码 这里可以通过qq邮箱获取 并且不唯一
pass: 'etrdgnwpniclsbfih'
}
}

const transporter = nodemailer.createTransport(config)

const mail = {
// 发件人 邮箱 '昵称<发件人邮箱>'
from: '车神-黄杰[email protected]',
// 主题
subject: '激活验证码',
// 收件人 的邮箱 可以是其他邮箱 不一定是qq邮箱
to: '[email protected]',
// 内容
text: 您的激活验证码为:${checkCode}, 请24小时内有效,请谨慎保管。 ,
//这里可以添加html标签
html: '车神-黄杰'
}

transporter.sendMail(mail, function(error, info){
if(error) {
return console.log(error);
}
transporter.close()
console.log('mail sent:', info.response)
})

 # 运行 nodemailer.js即可收到 邮件


注意
有时候发送成功,但收件人收不到邮件,可能因为网络问题,也有可能对方把它作为垃圾邮件了,在对方的垃圾邮箱可查找发送的邮箱。不要拿我的授权码以及邮箱测试,因为我的授权码随时会变。

标签:node,qq,const,Nodemailer,js,mail,邮箱,com,nodemailer
From: https://www.cnblogs.com/hxy--Tina/p/17337506.html

相关文章

  • json字符串格式化工具
    publicclassJsonFormatTool{/***单位缩进字符串。*/privatestaticStringSPACE="";/***返回格式化JSON字符串。**@paramjson未格式化的JSON字符串。*@return格式化的JSON字符串。*/publicstat......
  • JSch - 配置SFTP服务器SSH免密登录
    目录1.什么是SFTP2.什么是Jsch以及它的作用3.sftp服务器认证机制4.publickey和password两种方式登录sftp的API调用需求:做一个通过ssh免密登录的需求,是基于原先密码登录sftp服务器的代码上进行改造1.什么是SFTPSFTP是一个安全文件传送协议,可以为传输文件提供一种安全的加......
  • 03-Ajax传输json和XML
    title:03-Ajax传输json和XMLpublish:trueAjax传输JSONJSON的语法JSON(JavaScriptObjectNotation):是ECMAScript的子集。作用是进行数据的交换。语法更为简洁,网络传输、机器解析都更为迅速。语法规则:数据在键值对中数据由逗号分隔花括号保存对象方括号......
  • 使用OPENJSON()在ADO使用报错:指定了非不二类型的表达式
    背景:工单管理功能,供应商信息字段是存的JSON字符串(数据库是2008R2版本),这个功能没有使用ES,现在业务需要增加供应商相关信息的查询实现:利用OPENJSON函数用ADO拼接Sql执行的时候报以上错误,复制sql出来放到DBeaver里面执行又没有问题,同样的sql,至于任务紧张不展开研究了,换成存储过......
  • vscode 格式化统一配置 settings.json
    {"workbench.colorTheme":"DefaultDark+","eslint.autoFixOnSave":true,"editor.codeActionsOnSave":{"source.fixAll.eslint":true},"[javascript]":{ "......
  • Vue3+TS+Node打造个人博客(后端架构)
    在使用Express搭建后端服务时,主要关注的几个点是:路由中间件和控制器SQL处理响应返回体数据结构错误码Web安全环境变量/配置路由和控制器路由基本上是按模块或功能去划分的。首先是按模块去划分一级路由,各个模块的子功能相当于是用二级路由处理。简单举个例子,/article......
  • JS中定时执行,setTimeout和setInterval的区别,以及l解除方法
    评:setTimeout(Expression,DelayTime),在DelayTime过后,将执行一次Expression,setTimeout运用在延迟一段时间,再进行某项操作。setTimeout("function",time)设置一个超时对象setInterval(expression,delayTime),每个DelayTime,都将执行Expression.常常可用于刷新表达式.set......
  • Spring 3 mvc中返回pdf,json,xml等不同的view
    评:springmvc就是好,特别是rest风格的话,一个org.springframework.web.servlet.view.ContentNegotiatingViewResolver就可以根据不同的场景返回不同的view了,比如返回json,xml,pdf等.马上看代码实现先是一个简单的pojoJava代码收藏代码packagecom.hmkcode.vo;impor......
  • js 重置功能
    如果您只需要重置特定的ID$("#btn_Reset").click(function(){$("#OrderId").val("");$("#LoginName").val("");$("#GameName").val("");$("#Platform").val(&qu......
  • JSP自定义标签开发入门
    评:简单深入赞一般情况下开发jsp自定义标签需要引用以下两个包 importjavax.servlet.jsp.*;importjavax.servlet.jsp.tagext.*; 首先我们需要大致了解开发自定义标签所涉及到的接口与类的层次结构(其中SimpleTag接口与SimpleTagSupport类是JSP2.0中新引入的)。 目标1:自......