node笔记——调用免费qq的smtp发送html格式邮箱

文章目录

    • ⭐前言
    • ⭐smtp授权码获取
    • ⭐nodemailer
    • ⭐postman验证接口
    • ⭐结束

yma16-logo

⭐前言

大家好,我是yma16,本文分享关于node调用免费qq的smtp发送邮箱。
node系列往期文章
node_windows环境变量配置
node_npm发布包
linux_配置node
node_nvm安装配置
node笔记_http服务搭建(渲染html、json)
node笔记_读文件
node笔记_写文件
node笔记_连接mysql实现crud
node笔记_formidable实现前后端联调的文件上传
node笔记_koa框架介绍
node_koa路由
node_生成目录
node_读写excel
node笔记_读取目录的文件

饮水思源,回顾node发展历史

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时工具,它诞生于2009年。在 Node.js 诞生之前,JavaScript 只能在浏览器中使用,但是随着互联网和 Web 应用的发展,越来越多的开发者开始使用 JavaScript 开发后端服务,但是他们需要使用其他语言,如 Java、PHP、Python 等。这种开发方式存在着许多限制和不便之处。

Ryan Dahl 在创建 Node.js 的过程中,参考了一些已有的技术,包括 Google 的 V8 引擎,以及 Ruby 的 EventMachine 等。 Node.js 的目标是创建一个高性能、轻量级的、可伸缩的后端开发工具。它的出现,彻底改变了后端开发的方式,使得 JavaScript 可以在服务器端运行,使得前端和后端可以使用相同的语言进行开发。

随着 Node.js 的发展,它在社区和企业中的影响力越来越大。现在,Node.js 已经被广泛应用于 Web 开发、云计算、网络编程、大数据处理等领域。同时,Node.js 社区也以非常快的速度发展,它不断推出新的模块和框架,为开发者提供了更多的选择和便利。

效果:
app-email

⭐smtp授权码获取

注册qq账号、登录qq邮箱
链接:https://mail.qq.com/
进入设置
qq-email-setting
设置账号的smtp验证码
smtp-pass

⭐nodemailer

安装依赖

$ npm install nodemailer

官方示例:

"use strict";
const nodemailer = require("nodemailer");const transporter = nodemailer.createTransport({host: "smtp.forwardemail.net",port: 465,secure: true,auth: {// TODO: replace `user` and `pass` values from <https://forwardemail.net>user: 'REPLACE-WITH-YOUR-ALIAS@YOURDOMAIN.COM',pass: 'REPLACE-WITH-YOUR-GENERATED-PASSWORD'}
});// async..await is not allowed in global scope, must use a wrapper
async function main() {// send mail with defined transport objectconst info = await transporter.sendMail({from: '"Fred Foo 👻" <foo@example.com>', // sender addressto: "bar@example.com, baz@example.com", // list of receiverssubject: "Hello ✔", // Subject linetext: "Hello world?", // plain text bodyhtml: "<b>Hello world?</b>", // html body});console.log("Message sent: %s", info.messageId);// Message sent: <b658f8ca-6296-ccf4-8306-87d57a0b4321@example.com>//// NOTE: You can go to https://forwardemail.net/my-account/emails to see your email delivery status and preview//       Or you can use the "preview-email" npm package to preview emails locally in browsers and iOS Simulator//       <https://github.com/forwardemail/preview-email>//
}main().catch(console.error);

这里我封装了一下,为了接口对外暴露
node封装发送邮件的api

const nodemailer = require('nodemailer')//创建一个SMTP客户端配置对象
const transporter = nodemailer.createTransport({// 默认支持的邮箱服务包括:”QQ”、”163”、”126”、”iCloud”、”Hotmail”、”Yahoo”等service: "QQ",auth: {// 发件人邮箱账号user: '1432448610@qq.com',//发件人邮箱的授权码 需要在自己的邮箱设置中生成,并不是邮件的登录密码pass: 'smtp的授权码'}
})
const sendEmail=(toUserEmail,title,content)=>{return new Promise(resolve=>{// 配置收件人信息const receiver = {// 发件人 邮箱  '昵称<发件人邮箱>'from: `1432448610@qq.com`,// 主题subject:title,// 收件人 的邮箱 可以是其他邮箱 不一定是qq邮箱to:toUserEmail,// 可以使用html标签html: content};// 发送邮件transporter.sendMail(receiver, (error, info) => {if (error) {resolve({code:0,msg:error})}transporter.close()resolve({code:200,msg:'success'})})})
};
module.exports={sendEmail
}

暴露接口

const express = require("express");
const bodyParser = require('body-parser');
const {sendEmail}=require('./service/sendEmail.js');
const hostname = 'localhost';
const port = 6677;const app = express();
app.use(bodyParser())
app.listen(port,hostname, () => {console.log(`Server running at http://${hostname}:${port}/`);
});app.post("/sendEmail",async (req, res) => {try{const {toUserEmail,title,content}=req.bodyconsole.log(toUserEmail,title,content)if(!toUserEmail||!title||!content){res.json({code:-1,data:null,msg:'参数为空'})}const sendEmailRes=await sendEmail(toUserEmail,title,content)res.json({code:sendEmailRes.code,msg:sendEmailRes.msg,data:[]})}catch (e) {res.json({code:-1,data:null,msg:e})}
});

⭐postman验证接口

发送post请求postman-test
成功接受到邮箱信息
getmsg

⭐结束

本文分享到这结束,如有错误或者不足之处欢迎指出!
gaoda-img

👍 点赞,是我创作的动力!
⭐️ 收藏,是我努力的方向!
✏️ 评论,是我进步的财富!
💖 最后,感谢你的阅读!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/83481.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从零实现深度学习框架——Transformer从菜鸟到高手(一)

引言 &#x1f4a1;本文为&#x1f517;[从零实现深度学习框架]系列文章内部限免文章&#xff0c;更多限免文章见 &#x1f517;专栏目录。 本着“凡我不能创造的&#xff0c;我就不能理解”的思想&#xff0c;系列文章会基于纯Python和NumPy从零创建自己的类PyTorch深度学习框…

js 正则表达式

js 正则表达式 http://tool.oschina.net/regex https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Guide/Regular_Expressions 11 22 333

磁盘的管理

一、磁盘的分区 查看磁盘 lsblk fdisk -l 2、分区 没有e扩展&#xff0c;则都是主分区&#xff0c;已经有三个主分区了&#xff0c;剩下的全设置为扩展 查看分区结果&#xff1a; 二、格式化 三、挂载

JVM、JRE、JDK三者之间的关系

JVM、JRE和JDK是与Java开发和运行相关的三个重要概念。 再了解三者之前让我们先来了解下java源文件的执行顺序&#xff1a; 使用编辑器或IDE(集成开发环境)编写Java源文件.即demo.java程序必须编译为字节码文件&#xff0c;javac(Java编译器)编译源文件为demo.class文件.类文…

Web-WebApp Vue.js 目录结构

WebApp Vue.js 目录结构 目录解析 目录/文件 说明 build 最终发布的代码存放位置。config 配置目录&#xff0c;包括端口号等。我们初学可以使用默认的。node_modules npm 加载的项目依赖模块 src 这里是我们要开发的目录&#xff0c;基本上要做的事情都在这个目录里。里面包…

Pycharm如何打断点进行调试?

断点调试&#xff0c;是编写程序中一个很重要的步骤&#xff0c;有些简单的程序使用print语句就可看出问题&#xff0c;而比较复杂的程序&#xff0c;函数和变量较多的情况下&#xff0c;这时候就需要打断点了&#xff0c;更容易定位问题。 一、添加断点 在代码的行标前面&…

ATF(TF-A)安全通告 TFV-6 (CVE-2017-5753, CVE-2017-5715, CVE-2017-5754)

ATF(TF-A)安全通告汇总 目录 一、ATF(TF-A)安全通告 TFV-6 (CVE-2017-5753, CVE-2017-5715, CVE-2017-5754) 二、Variant 1 (CVE-2017-5753) 三、Variant 2 (CVE-2017-5715) 四、Variant 3 (CVE-2017-5754) 一、ATF(TF-A)安全通告 TFV-6 (CVE-2017-5753, CVE-2017-5715, C…

15-矩阵转置的拓展延伸

&#x1f52e;矩阵的转置✨ 前言 在很多时候我们拿到的数据本身可能并不会把点的坐标按列的方向排列起来&#xff0c;对于我们人类来说&#xff0c;更方便的方式依然是把这个点的坐标按行的方向排列&#xff0c;我们比较熟悉把矩阵看作为一个数据&#xff0c;在这里&#xff0…

06-3_Qt 5.9 C++开发指南_多窗体应用程序的设计(主要的窗体类及其用途;窗体类重要特性设置;多窗口应用程序设计)

文章目录 1. 主要的窗体类及其用途2. 窗体类重要特性的设置2.1 setAttribute()函数2.2 setWindowFlags()函数2.3 setWindowState()函数2.4 setWindowModality()函数2.5 setWindowOpacity()函数 3. 多窗口应用程序设计3.1 主窗口设计3.2 QFormDoc类的设计3.3 QFormDoc类的使用3.…

某科技公司提前批测试岗

文章目录 题目 今天给大家带来一家提前批测试岗的真题&#xff0c;目前已经发offer 题目 1.自我介绍 2.登录页面测试用例设计 3.如何模拟多用户登录 可以使用Jmeter,loadRunner性能测试工具来模拟大量用户登录操作去观察一些参数变化 4.有使用过Jmeter,loadRunner做过性能压…

数据库运维是什么意思?主要工作包含哪些?

还有不少小伙伴不知道数据库运维是什么意思&#xff1f;主要工作内容包含哪些&#xff1f;今天我们就一起来简单了解一下吧&#xff0c;仅供参考哦&#xff01; 数据库运维是什么意思&#xff1f; 数据库运维是指对数据库系统进行管理、监控和维护的过程&#xff0c;以确保数据…

ABPVNEXT-微服务框架基础入门

准备工作&#xff1a; 1.登录ABPvNext官网 网址 http://abp.io 2.跳转到商业版的说明文档&#xff0c;目前商业版没有中文&#xff0c;只能使用谷歌浏览器的内置翻译功能了 3.框架的相关环境要求&#xff0c;请自自行查看 适用于 Windows 的Visual Studio 2022 (v17.3) /…

适配器模式

泰国旅游使用插座问题 泰国插座用的是两孔的&#xff08;欧标&#xff09;&#xff0c;可以买个 多功能转换插头&#xff08;适配器&#xff09;&#xff0c;这样就可以使用了 适配器模式基本介绍 适配器模式&#xff08;Adapter Pattern&#xff09;将某个类的接口转换成客户端…

【M波段2D双树(希尔伯特)小波多分量图像去噪】基于定向M波段双树(希尔伯特)小波对多分量/彩色图像进行降噪研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

修改el-select样式;修改element-plus的下拉框el-select样式

修改el-select样式 .select_box{// 默认placeholder:deep .el-input__inner::placeholder {font-size: 14px;font-weight: 500;color: #3E534F;}// 默认框状态样式更改:deep .el-input__wrapper {height: 42px;background-color: rgba(0,0,0,0)!important;box-shadow: 0 0 0 …

PHP实现在线进制转换器,10进制,2、4、8、16、32进制转换

1.接口文档 2.laravel实现代码 /*** 进制转换计算器* return \Illuminate\Http\JsonResponse*/public function binaryConvertCal(){$ten $this->request(ten);$two $this->request(two);$four $this->request(four);$eight $this->request(eight);$sixteen …

状态模式(C++)

定义 允许一个对象在其内部状态改变时改变它的行为。从而使对象看起来似乎修改了其行为。 应用场景 在软件构建过程中&#xff0c;某些对象的状态如果改变&#xff0c;其行为也会随之&#xff0c;而发生变化&#xff0c;比如文档处于只读状态&#xff0c;其支持的行为和读写…

希尔排序——C语言andPython

前言 步骤 代码 C语言 Python 总结 前言 希尔排序&#xff08;Shell Sort&#xff09;是一种改进的插入排序算法&#xff0c;它通过将数组分成多个子序列进行排序&#xff0c;逐步减小子序列的长度&#xff0c;最终完成整个数组的排序。希尔排序的核心思想是通过排序较远距…

海外应用商店优化实用指南之元数据的迭代更新

随着每天都有新应用程序加入App Store和Google Play商店&#xff0c;许多应用程序都会针对与我们相同的关键词&#xff0c;虽然我们的元数据保持不变&#xff0c;但竞争对手的应用会重新编入索引&#xff0c;最终导致我们的关键词排名随着时间的推移稳步下降。 1、迭代的重要性…