首页 > 其他分享 >使用egg.js从qq发送验证码

使用egg.js从qq发送验证码

时间:2024-03-28 21:59:03浏览次数:22  
标签:qq const nodemailer js result SendEmailByUserNameByUserPasswordByUserEmail egg u

0.从qq获取授权码
1.下载
pnpm i nodemailer
 2.service层
async SendEmailByUserNameByUserPasswordByUserEmail(user){
        const nodemailer = require('nodemailer');
        const user_email = 'abcd.com'; //这里写发送者的qq号
        const auth_code = 'abcd';   //这里是qq授权码
        /*————————————————————————————————————————————*/
        const transporter = nodemailer.createTransport({    //初始化区块    //不用动
            service: 'qq',
            secureConnection: true,
            port: 465,
            auth: {
                user: user_email, // 账号
                pass: auth_code, // 授权码
            },
        });
        /*—————————————————————————————————————————————*/
        const verificationCode = Math.floor(Math.random() * 900000 + 100000);
        const mailOptions = {   //定义基础配置
            from: user_email, // 发送者,与上面的user一致
            to: user.UserEmail,   // 接收者,可以同时发送多个,以逗号隔开
            subject: "我是标题",   // 标题
            html: `这是验证码:${verificationCode}`
        };
        /*——————————————————————————————————————————————————*/
        let result;
        try {
        // 发送邮件
            await transporter.sendMail(mailOptions);
            result = {
                code: 0,
                msg: '验证码已发送',
            }
        } catch (error) {
            console.log(error)
        }
        return result;
    }
3.controller层
async SendEmailByUserNameByUserPasswordByUserEmail() {
        const { ctx } = this;
        const result = await this.ctx.service.userService.SendEmailByUserNameByUserPasswordByUserEmail(this.ctx.request.body);
        ctx.body = result
    }
4.路由层
router.post("/sendmail" , controller.userController.SendEmailByUserNameByUserPasswordByUserEmail)

标签:qq,const,nodemailer,js,result,SendEmailByUserNameByUserPasswordByUserEmail,egg,u
From: https://blog.csdn.net/m0_53785610/article/details/137023731

相关文章

  • [附源码]计算机毕业设计保险客户管理系统(JSP+java+springmvc+mysql+MyBatis)
    本项目包含程序+源码+数据库+LW+调试部署环境,文末可获取一份本项目的java源码和数据库参考。项目文件图项目介绍在现代保险行业中,客户管理系统对于提升客户服务水平、增强客户满意度和构建长期客户关系至关重要。随着大数据和人工智能技术的发展,保险公司迫切需要一个先进的......
  • [附源码]计算机毕业设计技术文档管理系统(JSP+java+springmvc+mysql+MyBatis)
    本项目包含程序+源码+数据库+LW+调试部署环境,文末可获取一份本项目的java源码和数据库参考。项目文件图项目介绍技术文档管理系统是企业信息化建设的重要组成部分,它关系到知识的积累、共享和管理效率。随着企业规模的扩大和业务的多样化,传统的文件管理方式已无法满足快速检......
  • 【JS球球大作战项目实战】+在线体验
    个人名片:......
  • 基于vue.js的购物商场的设计与实现
     有需要的同学,源代码和配套文档领取,加文章最下方的名片哦一、项目演示项目演示视频https://graduation-images.oss-cn-beijing.aliyuncs.com/videos/828%E5%A5%97ssm%E5%BD%95%E5%83%8F/10773_ssm616%E5%9F%BA%E4%BA%8Evue.js%E7%9A%84%E8%B4%AD%E7%89%A9%E5%95%86%E5%9C%BA......
  • js逆向学习- 爬虫下载「极简壁纸」图片
    声明:本文章仅供学习参考,请勿滥用爬虫下载目录声明:本文章仅供学习参考,请勿滥用爬虫下载一、确定抓取思路二、顺藤摸瓜总结前言 分享下爬取「极简壁纸」网站图片的爬虫流程,主要是分享个人处理的思路。网站地址(bs64):aHR0cHM6Ly9iei56enptaC5jbi9pbmRleA== 一、确定......
  • 探索多种数据格式:JSON、YAML、XML、CSV等数据格式详解与比较
    1.数据格式介绍数据格式是用于组织和存储数据的规范化结构,不同的数据格式适用于不同的场景。常见的数据格式包括JSON、YAML、XML、CSV等。数据可视化|一个覆盖广泛主题工具的高效在线平台(amd794.com)https://amd794.com/jsonformat2.JSON(JavaScriptObjectNotation)......
  • centos7下安装nodejs-v16.x
    今天记录一下centos7下安装nodejs-v16.x版本的nodejs官方下载:CNPMBinariesMirror(npmmirror.com)安装步骤1.下载nodejs-v16.x,其地址已经在上方附上2.将下载的"node-v16.13.1-linux-x64.tar.gz"上到/usr/local/nodejs。如果没有nodejs目录,请自行创建3.解压安装包tar-xvf......
  • js计算线性渐变的中间颜色值
    可能会使用js计算线性渐变的中间颜色值,写个demo记录下<style>#colors{margin-top:2rem;display:flex;}#colorsdiv{width:100px;height:100px;}</style><divid="colors"><div></div><div></div&......
  • Fastjson反序列化分析
    依赖先研究1.2.24版本的,版本高了就有waf了,不过也能绕,高版本以后再说<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.24</version></dependency><dependency><groupId&g......
  • python-json数据、pyecharts的入门使用(折线图)
    目录1. json数据格式 1.1 json.dumps()1.2 json.loads()2. pyecharts的入门使用(折线图)2.1  pyecharts使用的简单示例2.1.1 导包2.1.2 创建对象2.1.3 添加x轴数据2.1.4 添加y轴数据2.1.5 设置全局配置项2.1.6 render()方法,生成图像3. ......