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

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

总结

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

相关推荐
lizhongxuan36 分钟前
AI Agent 上下文压缩利器 Headroom
后端
kyriewen1 小时前
别再 console.log 了:5 个 Chrome DevTools 调试技巧,用过就回不去了
前端·javascript·面试
Csvn3 小时前
SSH 远程管理与安全加固 — 运维的守门之道
后端
IT_陈寒3 小时前
Python搞不定字符串编码?这破玩意坑我两小时!
前端·人工智能·后端
To_OC3 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
DigitalOcean4 小时前
Laravel 开发者已在 DigitalOcean 上开通超过 10 万台服务器
前端·laravel
星始流年4 小时前
从 Tool 到 Skill——基于 LangChain 的服务端Skill实现
前端·langchain·agent
菜鸟谢4 小时前
Rust 智能指针完整详解
后端
李惟4 小时前
开源本地通信库,纯客户端 RPC,像聊天一样通信
前端
YAwu114 小时前
深入解析 React 炫彩鼠标跟随标题组件:从坐标定位到动画性能
前端·react.js