首页 > web前端 > js教程 > 正文

如何在NestJS中轻松发送电子邮件?

聖光之護
发布: 2025-01-06 22:53:32
原创
438人浏览过

高效发送电子邮件:使用@nestixis/nestjs-mailer简化流程

在许多应用中,发送电子邮件至关重要,无论是用户通知、事务更新还是营销活动。然而,传统的电子邮件解决方案往往复杂且繁琐,需要整合邮件程序、模板语言,并处理各种依赖关系。

解决方案:

@nestixis/nestjs-mailer包提供了一种简洁、灵活且可靠的方案,简化了电子邮件发送流程。它结合了React和Nodemailer的优势,让开发者能够轻松创建动态电子邮件模板并发送邮件。

步骤详解:

  1. 安装包:

    使用npm安装:

    npm install @nestixis/nestjs-mailer
    登录后复制
  2. 模块配置:

    在你的NestJS应用中配置mailersdkmodule。为了测试,可以使用MailCatch等工具捕获邮件,无需发送到真实邮箱。示例配置如下:

    import { Mailersdkmodule } from '@nestixis/nestjs-mailer';
    import { Module } from '@nestjs/common';
    import { AppController } from './app.controller';
    import { AppService } from './app.service';
    
    @Module({
      imports: [
        Mailersdkmodule.register({
          auth: {
            user: 'username',
            password: 'password',
            host: 'sandbox-smtp.mailcatch.app',
            port: 2525,
            ssl: false,
          },
          from: 'your-email@example.com',
        }),
      ],
      controllers: [AppController],
      providers: [AppService],
    })
    export class AppModule {}
    登录后复制
  3. 创建电子邮件模板:

    为了创建美观的电子邮件,建议结合React和@react-email/components包。 在tsconfig.json文件中设置"jsx": "react"。

    以下是一个邀请新管理员的模板示例(invite-admin-with-account-template.tsx):

    import { body, container, head, html, img, link, section, text } from '@react-email/components';
    import * as React from 'react';
    
    export default function InviteAdminWithAccountTemplate({ translation, language, invitationHref, passwordHref, logoUrl }) {
      return (
        <container>
          {logoUrl ? @@##@@ : <text>{translation.titleInside}</text>}
          <text>{translation.contentPart1}</text>
          <text>{translation.contentPart2}</text>
          <text>
            {translation.contentPart3.subpart1}
            <link href={invitationHref} />
            {translation.contentPart3.subpart2}
            {translation.contentPart3.subpart3}
          </text>
          <text>
            {translation.contentPart4.subpart1}
            <link href={passwordHref} />
            {translation.contentPart4.subpart2}
          </text>
        </container>
      );
    }
    登录后复制
  4. 注入电子邮件发送器:

    将电子邮件发送器注入到你的服务中:

    import { EmailSenderInterface, MAILER_SDK_CLIENT } from '@nestixis/nestjs-mailer';
    import { Inject, Injectable } from '@nestjs/common';
    import InviteAdminWithAccountTemplate from './invite-admin-with-account-template';
    
    @Injectable()
    export class AppService {
      constructor(
        @Inject(MAILER_SDK_CLIENT)
        private readonly emailSender: EmailSenderInterface,
      ) {}
    
      async send(): Promise<void> {
        // ... (邮件内容和配置) ...
    
        await this.emailSender.sendEmail(
          'test@test.com',
          'Admin Invitation',
          emailContent,
        );
      }
    }
    登录后复制
  5. 完成!

    logo

    现在,你已经成功集成了nestjs-mailer。更多细节和高级功能,请参考nestjs-mailer的GitHub仓库。

如何在NestJS中轻松发送电子邮件?

以上就是如何在NestJS中轻松发送电子邮件?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号