博客
关于我
thinkphp-实现邮件发送
阅读量:607 次
发布时间:2019-03-11

本文共 1698 字,大约阅读时间需要 5 分钟。

###ThinkPHP5.0邮件发送配置与使用方法

通过以下步骤来实现ThinkPHP5.0环境下的邮件发送功能:

####一、前置配置

  • 开启必要服务

    • 登录163邮箱账号,依次开启SMTP服务、POP3服务、IMAP服务。
    • 请注意:客户端授权码只显示一次,必须妥善记录。
  • 下载并整理PHPMailer类库

    • 从官方下载PHPMailer压缩包,解压后将class.phpmailer.phpclass.smtp.php分别放置在thinkphp5/extend/phpmailer目录下。
  • 安装OpenSSL扩展

    • 检查php_openssl.dll是否存在于F:\xampp\php\ext或其他扩展目录中,确认存在后开启 OpenSSL扩展。
    • 打开php.ini,查找extension=php_openssl.dll并去掉注释。
  • 命名空间申明

    • 打开thinkphp5/extend/phpmailer/class.phpmailer.php,于文件开头加入namespace phpmailer;
  • ####二、邮件发送代码示例

    在ThinkPHP5的具体业务逻辑中,例如控制器中的index方法,加入以下代码:

    use phpmailer\phpmailer;class Index extends Controller {    public function index() {        $toemail = '收件人邮箱'; // 接收方邮箱地址        $mail = new PHPMailer();        $mail->isSMTP(); // SMTP协议传输        $mail->CharSet = "utf8"; // 设置utf8编码,避免乱码        $mail->Host = "smtp.163.com"; // 163邮箱SMTP服务器        $mail->SMTPAuth = true; // 启用身份验证        $mail->Username = "163邮箱用户名"; // 163邮箱账号        $mail->Password = "客户端授权密码"; // 客户端授权码        $mail->SMTPSecure = "ssl"; // 使用SSL协议        $mail->Port = 994; // 163邮箱SSL端口        $mail->setFrom("从账号@163.com", "邮件标题");        $mail->addAddress($toemail, "收件人显示名");        $mail->addReplyTo("从账号@163.com", "回复地址");                $mail->Subject = "邮件标题"; // 邮件主题        $mail->Body = "邮件正文内容"; // 邮件内容        // 如果需要添加附件,可以使用以下方式:        // $mail->addAttachment("附件路径");                if (!$mail->send()) {            echo "邮件发送失败:" . $mail->ErrorInfo;        } else {            echo "邮件发送成功.";        }    }}

    ####三、注意事项

  • 错误处理

    • 如果在$mail->send()时返回false,请检查ErrorInfo输出以确定具体错误类型。
  • 代码引用

    • 确保在使用PHPMailer前,使用use phpmailer\phpmailer;语句进行命名空间声明。
  • 常见问题

    • 如果出现SMTP Error: Data not accepted等错误,通常是邮件内容过滤问题。可以尝试更换部分关键词后重新发送。
  • 通过以上配置和代码示例,可以在ThinkPHP5.0环境下顺利实现邮件发送功能。

    转载地址:http://cdotz.baihongyu.com/

    你可能感兴趣的文章
    Oracle:ORA-00911: 无效字符
    查看>>
    TCP基本入门-简单认识一下什么是TCP
    查看>>
    Orcale表被锁
    查看>>
    org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned
    查看>>
    org.apache.poi.hssf.util.Region
    查看>>
    org.apache.zookeeper.KeeperException$ConnectionLossException: KeeperErrorCode = ConnectionLoss for /
    查看>>
    org.hibernate.HibernateException: Unable to get the default Bean Validation factory
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.web.multipart.MaxUploadSizeExceededException: Maximum upload size exceeded
    查看>>
    org.tinygroup.serviceprocessor-服务处理器
    查看>>
    org/eclipse/jetty/server/Connector : Unsupported major.minor version 52.0
    查看>>
    org/hibernate/validator/internal/engine
    查看>>
    SQL-36 创建一个actor_name表,将actor表中的所有first_name以及last_name导入改表。
    查看>>
    ORM sqlachemy学习
    查看>>
    orm总结
    查看>>
    os.path.join、dirname、splitext、split、makedirs、getcwd、listdir、sep等的用法
    查看>>
    os.system 在 Python 中不起作用
    查看>>
    OSCACHE介绍
    查看>>
    SQL--合计函数(Aggregate functions):avg,count,first,last,max,min,sum
    查看>>