群控系统服务端开发模式-应用开发-邮件工厂结构封装

首先在系统根目录下extend文件夹下创建邮件工厂文件夹并更名叫Mail。

一、邮件发送父类

在Mail目录下创建邮件发送父类并更名为MailSenderInterface.php,代码如下

复制代码
<?php
/**
 * 邮件发送父类
 * User: 龙哥·三年风水
 * Date: 2024/12/5
 * Time: 14:22
 */
namespace Mail;
interface MailSenderInterface
{
    /**
     * 单个邮件发送
     * User: 龙哥·三年风水
     * Date: 2024/12/5
     * Time: 14:29
     * @ param $emailSubject 邮件主题
     * @ param $emailContent 邮件内容
     * @ param string $emailAttachment 邮件附件
     * @ return mixed
     */

    public static function send($emailSubject, $emailContent, $emailAttachment = '');
}

二、具体类实现

在Mail目录下创建文件夹并命名为channel,然后在channel文件夹下,创建QQ邮件发送类、网易邮件发送类等,代码如下

复制代码
<?php
/**
 * 腾讯QQ邮件发送类
 * User: 龙哥·三年风水
 * Date: 2024/12/5
 * Time: 15:21
 */
namespace Mail\channel;
use Mail\MailSenderInterface;
class QqMailSender implements MailSenderInterface
{

    public function __construct($param){

    }

    /**
     * 单个邮件发送
     * User: 龙哥·三年风水
     * Date: 2024/12/5
     * Time: 14:29
     * @ param $emailSubject 邮件主题
     * @ param $emailContent 邮件内容
     * @ param string $emailAttachment 邮件附件
     * @ return mixed
     */
    public static function send($emailSubject, $emailContent, $emailAttachment = '')
    {
        // TODO: Implement send() method.
    }
}

三、邮件发送类实例

在Mail目录下创建邮件发送类实例并更名为MailSenderFactory.php,具体代码如下:

复制代码
<?php
/**
 * 创建邮件发送类实例工厂
 * User: 龙哥·三年风水
 * Date: 2024/12/5
 * Time: 14:32
 */
namespace Mail;
use app\model\param\Emailsms;
use Error\BaseError;
class MailSenderFactory
{
    protected static $instance=null;//缓存实例
    protected static $channel = [];//通道参数

    /**
     * 调用邮件类实例
     * User: 龙哥·三年风水
     * Date: 2024/12/5
     * Time: 14:49
     * @ param $recipient 邮箱名称
     */
    public static function create($recipient){
        $res = Emailsms::dataFind(['id' => 1],'email_id');
        if(empty($res) || empty($res['email_id']))throw new BaseError("未设置任何邮件发送通道",50000,200);
        $emailIds = explode(',',$res['email_id']);
        $emailType = explode('@',$recipient);
        self::$channel['recipient'] = $recipient;
        switch ($emailType[1]){
            case "qq.com":
                if(!in_array(1,$emailIds))throw new BaseError("未开启QQ邮件发送通道",50000,200);
                self::$channel['mail_id'] = 1;
                break;
            case "163.com":
                if(!in_array(2,$emailIds))throw new BaseError("未开启163邮件发送通道",50000,200);
                self::$channel['mail_id'] = 2;
                break;
            default:
                self::$instance = null;
                self::$channel = [];
                throw new BaseError("未设置任何短信发送通道",50000,200);
                break;
        }
        return self::$instance;
    }
}

四、提前说明

明天开始将完成邮件工厂类封装及测试。

相关推荐
掘金-我是哪吒2 分钟前
分布式微服务系统架构第158集:JavaPlus技术文档平台日更-JVM基础知识
jvm·分布式·微服务·架构·系统架构
东窗西篱梦37 分钟前
Redis集群部署指南:高可用与分布式实践
数据库·redis·分布式
Acrel_Fanny38 分钟前
Acrel-1000系列分布式光伏监控系统在湖北荆门一马光彩大市场屋顶光伏发电项目中应用
分布式
xufwind43 分钟前
spark standlone 集群离线安装
大数据·分布式·spark
zorro_z1 小时前
PHP语法基础篇(九):正则表达式
php
半新半旧2 小时前
Redis集群和 zookeeper 实现分布式锁的优势和劣势
redis·分布式·zookeeper
亲爱的非洲野猪2 小时前
Kafka “假死“现象深度解析与解决方案
分布式·kafka
CodeWithMe2 小时前
【Note】《Kafka: The Definitive Guide》第三章: Kafka 生产者深入解析:如何高效写入 Kafka 消息队列
分布式·kafka
虾条_花吹雪2 小时前
2、Connecting to Kafka
分布式·ai·kafka
Edingbrugh.南空4 小时前
Hadoop高可用集群搭建
大数据·hadoop·分布式