如何使用NestJs结合邮箱服务,定时发邮件提醒下班🫣🫣🫣

在平时上班过程中,我们经常会很认真的写代码,导致忘记了下班,同事都走光了,就剩一个人,这样就会浪费掉了公司的水电了,为了避免这样的事情发生,我们可以编写一个定时器,定时给自己发送邮件,这样就可以提醒到我们到点下班了。

创建邮箱服务和添加定时器

在 nest 中和使用定时器,首先我们应该安装特定的包,如下命令所示:

bash 复制代码
pnpm add nodemailer @nestjs/schedule

安装完成之后,我们要在 app.service.ts 中编写如下代码:

ts 复制代码
// src/app.service.ts
import { Injectable } from "@nestjs/common";
import { Cron } from "@nestjs/schedule";
import * as nodemailer from "nodemailer";
import { Transporter } from "nodemailer";

@Injectable()
export class AppService {
  private transporter: Transporter;

  constructor() {
    this.transporter = nodemailer.createTransport({
      host: "smtp.qq.com",
      port: 587,
      secure: false,
      auth: {
        user: "写你自己的@qq.com",
        pass: "写你自己的",
      },
    });
  }

  async sendMail(to: string, subject: string, text: string): Promise<void> {
    const mailOptions = {
      from: "example@qq.com", // 发送者
      to: to, // 接收者,可以是多个,逗号分隔
      subject: subject, // 主题
      text: text, // 文本内容
    };

    await this.transporter.sendMail(mailOptions);
  }

  @Cron("* * * * * *") // 每秒执行一次
  async handleCron() {
    await this.sendMail("写你自己的", "靓仔", "到点下班啦");
  }
}

当 serive 中的代码编写完成之后,我们要在 app.module 中导入该定时任务:

ts 复制代码
import { Module } from "@nestjs/common";
import { ScheduleModule } from "@nestjs/schedule";

import { AppController } from "./app.controller";
import { AppService } from "./app.service";

@Module({
  imports: [ScheduleModule.forRoot()],
  controllers: [AppController],
  providers: [AppService],
})
export class AppModule {}

这里代码编写完成了,我们启动项目,然后再查看邮箱,就可以看到消息轰炸提醒我们下班了:

总结

通过上面的例子我们实现了一个邮箱和定时器的功能,定时给我们发送邮件,只不过这个功能是每秒发送一次,可以根据需要把这个技巧用起来吧。

相关推荐
笙年几秒前
Promise详解:从回调地狱到优雅异步
前端·javascript
良木林1 分钟前
webpack:基本打包方法
前端·webpack·node.js
青衫码上行2 分钟前
【JavaWeb学习 | 第17篇】JSP内置对象
java·开发语言·前端·学习·jsp
core5122 分钟前
实战:用 Spring Boot 搭建 Model Context Protocol (MCP) 服务
java·spring boot·后端·model·模型·mcp
JaguarJack4 分钟前
FrankenPHP 是否是 PHP 的未来?
后端·php
国服第二切图仔7 分钟前
Electron for 鸿蒙PC项目实战之tooltip-component组件
javascript·electron·鸿蒙pc
VX:Fegn08957 分钟前
计算机毕业设计|基于springboot + vue手办商城系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
qq_570398577 分钟前
流式接口数据解析
前端·javascript·vue.js
柒儿吖9 分钟前
Electron for 鸿蒙PC - 番茄工作法计时器应用完整适配实践
javascript·electron·harmonyos
坐吃山猪9 分钟前
Electron入门示例
前端·javascript·electron