发送邮件

文档目录

 

  • 简介
  • IEmailSender
    • ISmtpEmailSender
    • NullEmailSender
  • 配置
  • 集成 MailKit
    • 安装
    • 集成
    • 用法
    • 定制

 

简介

发送邮件是一个很常用的任务,几乎每个应用都需要。Abp提供了一个基本的框架,用于简单地发送邮件并为它分离出了邮件服务的配置。

 

IEmailSender

它是一个你无需了解它的细节就能简单地用来发送邮件的服务,用法如下所示:

public class TaskManager : IDomainService
{
    private readonly IEmailSender _emailSender;

    public TaskManager(IEmailSender emailSender)
    {
        _emailSender = emailSender;
    }

    public void Assign(Task task, Person person)
    {
        //Assign task to the person
        task.AssignedTo = person;

        //Send a notification email
        _emailSender.Send(
            to: person.EmailAddress,
            subject: "You have a new task!",
            body: $"A new task is assigned for you: <b>{task.Title}</b>",
            isBodyHtml: true
        );
    }
}

我们简单地注入IEmailSender,并使用Send方法,该方法有几个重载版本,其中也有能接受MailMessage对象的重载(.net core里不能用,因为.net core不包含SmtpClient和MailMessage)。

 

ISmtpEmailSender

同样也有一个ISmtpEmailSender,它扩展了IEmailSender,添加了BuildClient方法,用来创建一个SmtpClient,然后可以直接使用SmtpClient(.net core里不能用,因为.net core不包含SmtpClient和MailMessage)。大部分情况下使用ISmtpEmailSender就已足够。

 

NullEmailSender

NullEmailSender是IEmailSender 的Null对象设计模式的实现,可用在单元测试和属性依赖注入中。

 

配置

邮件发送使用了设置管理系统来读取邮件发送的配置,所有设置的名称都以常量的形式定义在Abp.Net.Mail.EmailSettingNames类里。下列是它的值和描述:

  • Abp.Net.Mail.DefaultFromAddress:默认的邮件发送者的地址(如上面的示例)。
  • Abp.Net.Mail.DefaultFromDisplayName:默认的邮件发送者显示的名称(如上面的示例)。
  • Abp.Net.Mail.Smtp.Host: SMTP服务器的IP或域名(默认为127.0.0.1)。
  • Abp.Net.Mail.Smtp.Port: SMTP服务器的端口(默认为25)。
  • Abp.Net.Mail.Smtp.UserName: 当SMTP服务器要求认证时,需要提供的用户名。
  • Abp.Net.Mail.Smtp.Password: 当SMTP服务器要求认证时,需要提供的密码。
  • Abp.Net.Mail.Smtp.Domain: 当SMTP服务器要求认证时,需要提供的域名。
  • Abp.Net.Mail.Smtp.EnableSsl: 表明一个SMTP服务器是(true)否(false)需要使用SSL连接(默认为false)。
  • Abp.Net.Mail.Smtp.UseDefaultCredentials: 为True时使用默认的凭证代替提供的用户和密码(默认为true)。

 

集成 MailKit

由于.net core不支持标准的System.Net.Mail.SmtpClient,所以我们需要第三方供应商来发送邮件,幸运地是,MailKit 是默认的Smtpclient的一个很好的代替,而且微软也建议使用它。

Abp.MailKit 包优雅地集成到了Abp的邮件发送系统里,所以,你仍可像前面的方式通过MailKit使用IEmailSender。

 

安装

首先,安装Abp.MailKit 包到你的项目:

Install-Package Abp.MailKit

 

集成

添加AbpMailKitModule 依赖到你的模块:

[DependsOn(typeof(AbpMailKitModule))]
public class MyProjectModule : AbpModule
{
    //...
}

 

用法

你可以像前面描述的那样使用IEmailSender,因为Abp.MailKit包为它注册了MailKit的实现。也使用上面定义的配置。

 

定制

在创建MailKit的SmtpClient时,你可能会有额外的配置或自己的定制,此时,你可以用你自己的实现替换IMailKitSmtpBuilder 接口的注册,不过可以通过继承DefaultMailKitSmtpBuilder 更简单。比如,你想为所有的SSL连接提供一个凭证,这种情况下,你可以重写ConfigureClient方法,如下所示:

public class MyMailKitSmtpBuilder : DefaultMailKitSmtpBuilder
{
    public MyMailKitSmtpBuilder(ISmtpEmailSenderConfiguration smtpEmailSenderConfiguration) 
        : base(smtpEmailSenderConfiguration)
    {
    }

    protected override void ConfigureClient(SmtpClient client)
    {
        client.ServerCertificateValidationCallback = (sender, certificate, chain, errors) => true;

        base.ConfigureClient(client);
    }
}

然后在你的模块的PreInitialize方法中用你上面的实现替换IMailKitStmpBuilder接口的实现:

[DependsOn(typeof(AbpMailKitModule))]
public class MyProjectModule : AbpModule
{
    public override void PreInitialize()
    {
        Configuration.ReplaceService<IMailKitSmtpBuilder, MyMailKitSmtpBuilder>();
    }

    //...
}

(记得添加"using Abp.Configuration.Startup;"声明,因为ReplaceService 的扩展方法定义在这个命名空间里)。

转载于:https://www.cnblogs.com/kid1412/p/6976248.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用 HtmlEmail 发送邮件的示例代码: ```java import org.apache.commons.mail.EmailException; import org.apache.commons.mail.HtmlEmail; public class HtmlEmailDemo { public static void main(String[] args) { String smtpServer = "smtp.163.com"; // 邮件服务器的地址 String username = "yourusername"; // 发件人的账号 String password = "yourpassword"; // 发件人的密码 String fromAddress = "yourusername@163.com"; // 发件人的邮箱地址 String toAddress = "recipient@example.com"; // 收件人的邮箱地址 String subject = "测试邮件主题"; // 邮件的主题 String content = "<html><body><h1>测试邮件内容</h1><p>这是一封测试邮件。</p></body></html>"; // 邮件的内容,支持 HTML 格式 HtmlEmail email = new HtmlEmail(); email.setHostName(smtpServer); email.setAuthentication(username, password); email.setCharset("utf-8"); try { email.setFrom(fromAddress); email.addTo(toAddress); email.setSubject(subject); email.setHtmlMsg(content); email.send(); System.out.println("邮件发送成功!"); } catch (EmailException e) { e.printStackTrace(); System.out.println("邮件发送失败!"); } } } ``` 需要注意的是,使用 HtmlEmail 发送邮件需要引入 Apache Commons Email 的依赖库。在 Maven 中,可以在 pom.xml 文件中添加以下依赖: ```xml <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-email</artifactId> <version>1.5</version> </dependency> ``` 另外,本示例中使用的是 163 邮箱作为邮件服务器,如果需要使用其他邮箱,需要将 `smtpServer` 和 `fromAddress` 的值替换为对应的值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值