nodemailer的使用,nodejs发送邮件

2018-11-19 15:10:23

如何使用

这里就先上配置

nodejs: v6.9.4

npm: 3.10.10

nodemailer: ^4.1.0

const params = {
  host: 'smtp.163.com', // 设置服务
  port: 465, // 端口
  sercure: true, // 是否使用TLS,true,端口为465,否则其他或者568
  auth: {
    user: config.user, // 邮箱和密码
    pass: config.emailPwd
  }
}

// 邮件信息
const mailOptions = {
  from: config.user, // 发送邮箱
  to: config.emailTo, // 接受邮箱
  subject: config.title, // 标题
  html: config.html // 内容
}

// 发送邮件
const transporter = nodemailer.createTransport(params)
transporter.sendMail(mailOptions, (error, info) => {
  if (error) {
    return console.log(error);
  }
  console.log('Message %s sent: %s', info.messageId, info.response);
  // success
  // ...
})

按照这个格式,发送成功是没什么问题的。不过在密码这里要注意,不是邮箱的登录密码。

163和qq获取授权码

163邮箱的话,要开启POP3/SMTP服务,在设置 --> POP3/SMTP/IMAP页面,设置。开通后会有个授权码的,配置里的密码,就是用这个授权码

qq邮箱的话,同样也要开启这个服务,设置 --> 账户 --> POP3服务,点击开启,就会有个授权码,如果忘了记录,在开启服务下面有个“生成授权码”的,可以获取到的。

这样qq和163就能开启了

Gmail

如果是Gmail的话,这个就有点麻烦了,在nodemailer官网也有说到:

Gmail either works well or it does not work at all. It is probably easier to switch to an alternative service instead of fixing issues with Gmail. If Gmail does not work for you then don't use it.

我这里用自己的谷歌邮箱试了下,在上面的配置修改一下


const params = {
  service: 'Gmail', // 注意,host修改为service
  port: 465, // 端口
  sercure: true, // 是否使用TLS,true,端口为465,否则其他或者568
  auth: {
    user: config.user, // 邮箱和密码
    pass: config.emailPwd
  }
}


如果这样不行的话,打开这个链接,开启谷歌允许不够安全应用

如果还不行的话,就要配置谷歌的XOAuth2了

配置XOAuth2

就算使用了这种方法,也未必可能成功

这是我在网上找到的配置XOAuth2的教程

在这里创建一个凭据,选择OAuth客户端ID,应用类型选择“网页应用”,然后填写名称,重定向URI要记得填写,我填写的是这个"https://developers.google.com/oauthplayground"

图片描述

然后记录下id和密钥

进入此页面,进行配置

图片描述

填写之前的id和密钥

然后就是step1,选择api

图片描述

到step2,点击'Exchange authorization code for tokens'按钮,生成token,这样就完成了。

回到nodejs,重写下配置

const params = {
  service: 'Gmail',
  auth: {
    type: 'OAuth2',
    user: config.user,
    clientId: config.clientId,
    clientSecret: config.clientSecret,
    refreshToken: config.refreshToken,
    accessToken: config.accessToken
  }
}

我这里测试是成功的(本地服务器),如果还不成功的话,这个你只能在搜搜有什么解决方法了。

这里是官方的OAuth2配置

nodemailer其他功能

这里列出我自己用过的功能,nodemailer看官方介绍,貌似是很多功能的

发送多个用户:

// 在配置发送信息的时候const mailOptions = {
  from: config.user, // 发送邮箱
  to: config.emailTo + ', ' + config.emailTo2 // 用', '分隔}

发送html内容

const mailOptions = {
  ....  html: config.html // 这里可以是html字符串}

发送附件

可以同时发送多个

const mailOptions = {
  ...
  attachments: [{
    filename: 'test.txt',
    content: 'hello world!'
  },{
    filename: 'test.txt',
    content: 'hello world!',
    contentType: 'text/plain'
  }]
}

html 显示图片

如果直接在图片上写上图片地址,在 qq 和谷歌邮箱都是没法直接显示的。qq 邮箱有一个查看图片的按钮,点击后才能显示。

如果使用附件的形式,是可以直接显示图片的。

// 伪代码var img = require("fs").readFileSync('./images/1.jpeg')
attachments: [
  {    filename: '1.jpeg',    content: img,    cid: '00000001'
  }
]

html: `<img src='cid:00000001' />`

官方给出的配置

  • filename - filename to be reported as the name of the attached file. Use of unicode is allowed.

  • content - String, Buffer or a Stream contents for the attachment

  • path - path to the file if you want to stream the file instead of including it (better for larger attachments)

  • href – an URL to the file (data uris are allowed as well)

  • contentType - optional content type for the attachment, if not set will be derived from the filename property

  • contentDisposition - optional content disposition type for the attachment, defaults to ‘attachment’

  • cid - optional content id for using inline images in HTML message source

  • encoding - If set and content is string, then encodes the content to a Buffer using the specified encoding. Example values: ‘base64’, ‘hex’, ‘binary’ etc. Useful if you want to use binary attachments in a JSON formatted email object.

  • headers - custom headers for the attachment node. Same usage as with message headers

  • raw - is an optional special value that overrides entire contents of current mime node including mime headers. Useful if you want to prepare node contents yourself

总结

刚使用nodemailer踩了不少坑,弄了我一天,Gmail不怎么稳定,后面主管就叫换成qq了,据说qq企业邮箱发送邮件的次数比较多。这篇文章就是记录下使用nodemailer的一些经验。


  • 2019-11-29 13:50:29

    图片连接处出现白线

    block导致,只要父元素设置font-size:0或者设置img display: block; 便可。但是我设置了没有用,这条线不是所有的机型都有,而且页面滚动之后又消失,我琢磨半天,各种尝试,发现把图片高度减少(增加)1px就解决了。因为我们的项目是用postcss-px-to-viewport,我每张图片都是设置高度的,应该是数值转换出现偏差。

  • 2019-11-29 13:54:07

    粗略计算多边形中心点(并不是很准确,但简单好用)

    也是再做栅栏系统,搜索如何获取多边形中心点的问题上,发现了这个,简单易于理解,但是并不是特变准确,但也不影响使用。 后来发现了新的算法,并且百度地图也提供相应的api。 具体内容我写在了前面的文章,大家可以找一下。

  • 2019-11-29 14:20:38

    vue,vuthis.$parent算法

    由于组件嵌套,其实vue parent的位置也改变了,我们可以通过下面的图片,来看一下,parent到底什么哪一层

  • 2019-11-29 14:23:24

    百度地图 多个标记点设置最佳视角

    通过下面的语法,我们可以为不规则图形,以及过大的图形进行地图适配,更好的展示我们画的图形,当然,如果展示所有的图形,我们可以暴力的把所有的点组合起来进行展示,点过多不知道会不会影响性能,不过我们也可以从后台精简点数,不过地球是圆的,不知道好不好做。

  • 2019-12-01 08:00:16

    PHP中的HTTP_HOST和SERVER_NAME有什么区别

    多域名指向同一个php服务器,用nginx做代理,获取SERVER_NAME都是第一个域名,这就尴尬了,至今不明白咋回事,最后用HTTP_HOST解决都,这个暂时倒是准确。

  • 2019-12-01 08:04:30

    laravel多路由配置,也可以做根据域名都动态路由

    在用laravel 框架开发大型应用的时候,由于 laravel 默认是只有一个路由文件,如果把项目所有模块的路由放在一个路由文件下,那么该路由文件就显得很臃肿,以至于后期难以维护,解决方案是根据不同模块配置不同路由文件。