博客
关于我
nodemailer实现node发送邮件
阅读量:402 次
发布时间:2019-03-05

本文共 2327 字,大约阅读时间需要 7 分钟。

作为一个前端er,利用node独立做一些全栈小项目,是很有效率和必要的。

需要:

  做一个活动报名页面,用户填好的表单需要被工作人员收到,一想到把数据存数据库,还需要给工作人员写一个管理页面就觉得很麻烦。

  把表单数据通过邮件方式发送到相关人邮箱,很讨巧,很节约开发成本,就这样做。

 

核心模块:nodemailer

 

看看package.json

{  "devDependencies": {    "gulp": "^3.8.11",    "gulp-imagemin": "^2.2.1",    "gulp-less": "^3.0.3",    "gulp-notify": "^2.2.0",    "gulp-uglify": "^1.2.0",    "gulp-watch": "^4.2.4",    "require-dir": "^0.3.0"  },  "dependencies": {    "body-parser": "^1.15.0",    "express": "^4.13.4",    "nodemailer": "^2.3.0",    "swig": "^1.4.2"  }}

 

  • devDependencies里全是gulp模块
  • 引入body-parser模块可以通过req.body.xx获取到表单的数据
  • 常规使用express
  • nodemailer用来支持发送邮件
  • swig是node的一个模板引擎

使用nodemailer:

1.这里用到的是QQ邮箱,配置好地址和自己的账户名和密码

var nodemailer = require("nodemailer");var smtpTransport = nodemailer.createTransport({    host: 'smtp.exmail.qq.com',    port: 465,    secure: true, // use SSL    auth: {        user: 'yourqq@qq.com',        pass: 'password'    }});

 

2.from和to设置邮件发送者和收件者的邮箱地址,

   subject邮件title

   html邮件内容

   smtpTransport.sendMail执行发送,这里的res是express router的响应参数,这里只贴主要代码,详细代码最后发github地址

var mailOptions = {  from: "yourqq@qq.com",  to: "toqq@qq.com",  subject: "node邮件",  html:     "姓名:  "+name+"
"+  "性别: " + sex + "
"+  "电话: " + phone + "
"+  "邮箱: " + email + "
"+  "QQ: " + qq + "
"+  "年龄: " + age + "
"+  "联系地址:
" + address + "
"+  "所在院校及专业:
" + school + "
"+  "学校地址:
" + schooladdress + "
"+  "跟我们说说你的大学吧:
" + des + "
"+  "个人书单及评价:
" + book + "
"}smtpTransport.sendMail(mailOptions, function(err, resp){  if(err){    res.send({      code: 201,      msg: "报名失败,请重试"    })  }else{    res.send({      code: 200,      msg: "报名成功"    })  }  smtpTransport.close();//关闭连接池});

其实很简单,核心代码就是这些~

绑定路由:

app.get('/', function(req, res) {  res.render('index');})app.get('/success', function(req, res) {  res.render('success');})app.post('/join', function(req, res){    var name = req.body.name,  sex = req.body.sex,  phone = req.body.phone,  email = req.body.email,  qq = req.body.qq,  age = req.body.age,  address = req.body.address,  school = req.body.school,  schooladdress = req.body.schooladdress,  des = req.body.des,  book = req.body.book;  //next do send})

前端当然也有一些事情要做,写好页面,验证表单,提交表单。

当前只有两个页面,报名页面和报名成功页面。
页面内容不再叙述,详情看下面git地址

需要注意的问题:

  • 用不同的邮箱发送邮件,需要找到相应官方api地址
  • 邮件内容的html是有一定规则的,每个三方邮箱的规则都不同,可以查阅相关通用资料

  

转载地址:http://yhxzz.baihongyu.com/

你可能感兴趣的文章
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>