如何使用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 {}

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

总结

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

相关推荐
2501_940007893 分钟前
Flutter for OpenHarmony三国杀攻略App实战 - 战绩记录功能实现
开发语言·javascript·flutter
摘星编程8 分钟前
React Native + OpenHarmony:自定义useEllipsis省略号处理
javascript·react native·react.js
2401_8590490818 分钟前
git submodule update --init --recursive无法拉取解决
前端·chrome·git
这是个栗子36 分钟前
【Vue代码分析】前端动态路由传参与可选参数标记:实现“添加/查看”模式的灵活路由配置
前端·javascript·vue.js
刘一说44 分钟前
Vue 动态路由参数丢失问题详解:为什么 `:id` 拿不到值?
前端·javascript·vue.js
熊猫钓鱼>_>1 小时前
动态网站发布部署核心问题详解
前端·nginx·容器化·网页开发·云服务器·静态部署
方也_arkling1 小时前
elementPlus按需导入配置
前端·javascript·vue.js
好好研究1 小时前
Spring Boot - Thymeleaf模板引擎
java·spring boot·后端·thymeleaf
爬山算法1 小时前
Hibernate(76)如何在混合持久化环境中使用Hibernate?
java·后端·hibernate
爱吃大芒果1 小时前
Flutter for OpenHarmony 实战: mango_shop 资源文件管理与鸿蒙适配
javascript·flutter·harmonyos