【程序设计】做一个发送系统邮件的功能,如何设计数据表? 转至元数据结尾

简介: 重构系统邮件发送旨在实现统一的邮件发送功能,通过公共API提供服务。设计包括两个核心数据表:`mail` 表用于存储邮件基本信息,如邮件ID、业务类型、发送者、标题、内容、附件信息、发送状态和时间戳;`mail_receiver` 表记录邮件接收者信息,包括邮件ID、接收者邮箱、接收者类型、发送状态和重试次数。为了优化查询性能,建议创建`Email_Content`表,将`content`和`attach_file`从`Email`表中分离,以减少主表大小。这有助于提高主表的查询速度,并通过定期的数据结转策略,确保热表只存储最近的数据。

功能说明

随着系统的不断庞大,需要我们站在更高的层次,来对系统实现进行重构。例如,发送邮件,在不同的业务、不同的业务节点,会涉及到发送邮件。因此,有必要做一个发送系统邮件的功能,通过暴露公共API实现统一复用。本文只谈数据表结构设计。

通过对发送邮件功能进行分析,我们使用下面的模型:

 

数据用例:

 

 

那么,如何设计数据表呢?

我们来看下面的设计

mail(邮件发送表)
列名 数据类型 说明
id bigint(20) PK,AUTO_INCREMENT
biz_type char(40) 业务操作标识
sender varchar(255) 发件人邮箱
title varchar(500) 邮件标题
content varchar(8192) 邮件内容
attach_file varchar(2048) 附件信息
send_status char(40) 发送状态
send_time datetime 发送时间
create_time datetime 创建时间
update_time datetime 更新时间
mail_receiver(邮件接收人表)
列名 数据类型 说明
id bigint(20) PK,AUTO_INCREMENT
mail_id bigint(20) 关联mail表id
receiver varchar(255) 收件人邮箱
receiver_type varchar(10) 收件人类型:TO 收件人,CC 抄送人
send_status char(40) 发送状态
retry_times int(10) 重试次数
create_time datetime 创建时间

如果考虑到查询性能的话,可以创建一个mail_content表,将 content 和 attach_file 从mail 表中分离出来。另外,该表的数据可以定期做数据结转,保证热表只存近一段时间的数据即可。

mail_content(邮件内容表)
列名 数据类型 说明
id bigint(20) PK,AUTO_INCREMENT
mail_id bigint(20) 关联mail表id
content varchar(8192) 邮件内容
attach_file varchar(2048) 附件信息
create_time datetime 创建时间

 

 

 

 

【附】java 如何校验邮箱是否存在?

AI:在Java中,验证电子邮箱是否存在不是一个简单的任务,因为SMTP服务器通常不会对外公开API来确认邮箱是否存在。然而,你可以尝试发送一封测试邮件来验证邮箱是否存在。如果邮件发送成功,通常意味着邮箱至少是有效的,并且至少在某个时点是存在的。(可以使用JavaMail API发送邮件)

以下是一个使用JavaMail API发送邮件的示例代码,你可以使用这个方法来验证邮箱是否存在:

import javax.mail.*;
import javax.mail.internet.*;
  
public class EmailValidator {
    public static boolean validateEmail(String email) {
        boolean isValid = false;
  
        try {
            final String SMTP_HOST_NAME = "smtp.example.com"; // 替换为你的SMTP服务器
            final String from = "from@example.com"; // 替换为你的邮箱
  
            // 建立Session
            Properties props = new Properties();
            props.put("mail.smtp.host", SMTP_HOST_NAME);
            Session session = Session.getDefaultInstance(props, null);
  
            // 创建邮件
            MimeMessage message = new MimeMessage(session);
            message.setFrom(new InternetAddress(from));
            message.addRecipient(Message.RecipientType.TO, new InternetAddress(email));
            message.setSubject("Email Verification");
            message.setText("This is a test mail");
  
            // 发送邮件
            Transport.send(message);
  
            isValid = true;
        } catch (AddressException ae) {
            ae.printStackTrace();
        } catch (MessagingException me) {
            if (me.getNextException() instanceof SendFailedException) {
                // 邮箱不存在
                isValid = false;
            } else {
                me.printStackTrace();
            }
        }
  
        return isValid;
    }
  
    public static void main(String[] args) {
        String email = "user@example.com"; // 要验证的邮箱
        boolean isValid = validateEmail(email);
        System.out.println("Is email valid? " + isValid);
    }
}

我用我司notice@ss.com向不存在的guozhan.zhang123@ss.com发送邮件,可以通过异常识别出来发送失败,但用它向一个不存在的126邮箱发送,是没有异常提示的。

同样地,我用126邮箱服务给无效的126邮箱发送邮件,可以通过异常识别出来发送失败,但用它向一个不存在的ss.com邮箱发送,是没有异常提示的。不过呢,在126邮箱里可以看到,会收到一个“系统退信”的邮件。

image.png

 

【附】设计物料:

目录
相关文章
|
7月前
|
NoSQL 关系型数据库 MySQL
多人同时导出 Excel 干崩服务器?怎样实现一个简单排队导出功能!
业务诉求:考虑到数据库数据日渐增多,导出会有全量数据的导出,多人同时导出可以会对服务性能造成影响,导出涉及到mysql查询的io操作,还涉及文件输入、输出流的io操作,所以对服务器的性能会影响的比较大;结合以上原因,对导出操作进行排队; 刚开始拿到这个需求,第一时间想到就是需要维护一个FIFO先进先出的队列,给定队列一个固定size,在队列里面的人进行排队进行数据导出,导出完成后立马出队列,下一个排队的人进行操作;还考虑到异步,可能还需要建个文件导出表,主要记录文件的导出情况,文件的存放地址,用户根据文件列表情况下载导出文件。
多人同时导出 Excel 干崩服务器?怎样实现一个简单排队导出功能!
|
5月前
|
存储 前端开发 Java
若依修改----数据字典,可以用于维护系统中常见的静态数据,为什么不写死,用字典维护?数据字典的好处是一个地方编写数据,在多个地方,复用他,静态选项这里填完,换其他,用户性别这里的男女,就转成而来字典
若依修改----数据字典,可以用于维护系统中常见的静态数据,为什么不写死,用字典维护?数据字典的好处是一个地方编写数据,在多个地方,复用他,静态选项这里填完,换其他,用户性别这里的男女,就转成而来字典
|
5月前
|
SQL 前端开发 Java
若依修改03----利用若依代码生成器,生成课程管理的前后端代码,课程的条件搜索接口,一旦数据表创建好了,直接交给若依代码的生成器就好了,配置代码生成信息,包含基本信息,字段信息,生成信息。字段信息决
若依修改03----利用若依代码生成器,生成课程管理的前后端代码,课程的条件搜索接口,一旦数据表创建好了,直接交给若依代码的生成器就好了,配置代码生成信息,包含基本信息,字段信息,生成信息。字段信息决
|
5月前
|
存储 JavaScript 前端开发
文本,三步走构思,富文本点击提交能够存储到数据库当中(下),最快的方法,还是会看资料,因此会整合资料最好,直接看资料最快,因为是JWT的资料,我们要设置好登录的内容,看登录的地方怎样写的
文本,三步走构思,富文本点击提交能够存储到数据库当中(下),最快的方法,还是会看资料,因此会整合资料最好,直接看资料最快,因为是JWT的资料,我们要设置好登录的内容,看登录的地方怎样写的
|
7月前
|
C语言
C 语言文件处理全攻略:创建、写入、追加操作解析
在 C 语言中,您可以通过声明类型为 FILE 的指针,并使用 fopen() 函数来创建、打开、读取和写入文件:
246 0
|
7月前
|
移动开发 前端开发
基于若依的ruoyi-nbcio流程管理系统修复自定义业务表单的取消终止功能
基于若依的ruoyi-nbcio流程管理系统修复自定义业务表单的取消终止功能
68 3
|
移动开发
微信h5扫码接口范例:多个扫码框支持的办法,通过引入一个参数来区分及使用localStorage保证之前扫到的数据不丢失
微信h5扫码接口范例:多个扫码框支持的办法,通过引入一个参数来区分及使用localStorage保证之前扫到的数据不丢失
117 0
|
SQL Java 关系型数据库
从系统报表页面导出20w条数据到本地只用了4秒,我是如何做到的
最近有个学弟找到我,跟我描述了以下场景: 他们公司内部管理系统上有很多报表,报表数据都有分页显示,浏览的时候速度还可以。但是每个报表在导出时间窗口稍微大一点的数据时,就异常缓慢,有时候多人一起导出时还会出现堆溢出。 他知道是因为数据全部加载到jvm内存导致的堆溢出。所以只能对时间窗口做了限制。以避免因导出过数据过大而引起的堆溢出。最终拍脑袋定下个限制为:导出的数据时间窗口不能超过1个月。
|
安全 API 数据安全/隐私保护
在编写API接口的技术文章时应注意的内容
编写API接口技术文章时建议包含的内容,通过清晰的说明和示例,可以帮助读者准确理解和使用API接口。
|
缓存 安全 算法
CleanMyMac X4.20都包含有哪些功能?
CleanMyMac X4.20版是一款运行在macOS系统中的专业清理软件,以安装方便、使用简易、功能完善等特点而闻名。CleanMyMac X在功能方面可以说是做到了极致,下面让我们看一下CleanMyMac X都包含有哪些功能。
102 0