如何使用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: "[email protected]", // 发送者
      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 {}

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

总结

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

相关推荐
涛々1 分钟前
uniapp-vue3-js-vite-pinia-eslint 快速开发模板
javascript·uni-app·uniapp+vue3模板
解道Jdon11 分钟前
最新苹果液体玻璃Liquid Glass效果CSS实现
javascript·reactjs
啊~哈31 分钟前
页面弹窗适配问题
前端·javascript·vue.js
工呈士38 分钟前
构建优化策略:Tree Shaking、代码分割与懒加载
前端·面试
用户3273242098741 分钟前
logger2js - JavaScript日志与调试工具库
javascript
import_random41 分钟前
[macos]rocketmq(安装)
后端
骑自行车的码农43 分钟前
React Suspense实现原理深度解析 1
前端·react.js
安然dn1 小时前
Interact.js 一个轻量级拖拽库
javascript
还是一只小牛1 小时前
探秘 React Native:线程探索及桥优化
android·前端
Face1 小时前
Vue源码核心模块解析
前端·vue.js