0

0

解决 PHPMailer 突然无法发送邮件的问题 (Office365)

聖光之護

聖光之護

发布时间:2025-08-22 19:16:11

|

281人浏览过

|

来源于php中文网

原创

解决 phpmailer 突然无法发送邮件的问题 (office365)

本文旨在帮助开发者解决在使用 PHPMailer 通过 Office365 发送邮件时,突然出现连接失败的问题。主要原因是 Office365 逐步停止支持旧版本的 TLS 协议,导致旧的 PHP 配置无法正常工作。本文将提供更新 PHP 版本这一解决方案,并提供详细步骤和注意事项,确保邮件发送功能恢复正常。

问题分析

近期,许多开发者在使用 PHPMailer 通过 Office365 发送邮件时遇到了连接失败的问题。从提供的调试信息来看,客户端可以成功连接到 Office365 的 SMTP 服务器,并且服务器也返回了 220 2.0.0 SMTP server ready 的响应。然而,随后却出现了 SMTP Error: Could not connect to SMTP host. 的错误,表明连接在 TLS 握手阶段失败。

这通常是因为 Office365 已经停止支持某些旧版本的 TLS 协议。如果你的 PHP 环境仅支持这些旧协议,那么就无法与 Office365 服务器建立安全的连接,从而导致邮件发送失败。

解决方案:更新 PHP 版本

解决此问题的最佳方法是更新你的 PHP 版本。较新的 PHP 版本通常支持更新的 TLS 协议,例如 TLS 1.2 或更高版本,这些协议仍然被 Office365 支持。

立即学习PHP免费学习笔记(深入)”;

Otter.ai
Otter.ai

一个自动的会议记录和笔记工具,会议内容生成和实时转录

下载

步骤:

  1. 确认当前 PHP 版本: 使用 php -v 命令在终端或命令行中查看当前 PHP 版本。
  2. 升级 PHP 版本: 根据你的操作系统和服务器环境,选择合适的 PHP 升级方式。
    • Linux (Ubuntu/Debian): 使用 apt update 和 apt upgrade 命令更新系统软件包,或者使用 apt install phpX.X 安装指定版本的 PHP (将 X.X 替换为所需的版本号,例如 php7.4 或 php8.1)。
    • Windows (XAMPP/WAMP): 下载并安装最新版本的 XAMPP 或 WAMP,这些软件包通常包含最新版本的 PHP。
    • cPanel/Plesk: 登录到你的主机控制面板,查找 PHP 版本管理工具,并选择升级到最新版本。
  3. 验证 PHP 版本: 升级完成后,再次使用 php -v 命令确认 PHP 版本已经更新。
  4. 重启 Web 服务器: 确保重启 Apache 或 Nginx 等 Web 服务器,以使新的 PHP 版本生效。

示例代码 (PHPMailer 配置):

<?php
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;

require 'path/to/PHPMailer/src/Exception.php';
require 'path/to/PHPMailer/src/PHPMailer.php';
require 'path/to/PHPMailer/src/SMTP.php';

$mail = new PHPMailer(true);

try {
    //服务器配置
    $mail->CharSet ="UTF-8";   //设定邮件编码
    $mail->SMTPDebug = 0;                      // 启用详细调试输出
    $mail->isSMTP();                                            // 使用SMTP发送
    $mail->Host       = 'smtp.office365.com';                     // SMTP服务器
    $mail->SMTPAuth   = true;                                   // 启用SMTP身份验证
    $mail->Username   = 'your_email@example.com';                     // SMTP 用户名
    $mail->Password   = 'your_password';                               // SMTP 密码
    $mail->SMTPSecure = PHPMailer::ENCRYPTION_STARTTLS;         // 启用TLS加密,`PHPMailer::ENCRYPTION_SMTPS` 也可使用
    $mail->Port       = 587;                                    // TCP端口,连接到哪个端口

    //收件人
    $mail->setFrom('your_email@example.com', 'Your Name');
    $mail->addAddress('recipient@example.com', 'Recipient Name');     // 添加收件人

    //内容
    $mail->isHTML(true);                                  // 设置邮件格式为HTML
    $mail->Subject = '邮件主题';
    $mail->Body    = '邮件正文内容';
    $mail->AltBody = '非HTML邮件客户端的备用内容';

    $mail->send();
    echo '邮件已发送';
} catch (Exception $e) {
    echo "邮件发送失败: {$mail->ErrorInfo}";
}

注意事项:

  • 备份: 在升级 PHP 版本之前,务必备份你的网站和数据库,以防止意外情况发生。
  • 兼容性: 升级 PHP 版本后,检查你的网站代码和第三方库是否与新版本兼容。可能需要进行一些小的修改。
  • SMTP Options: 不再需要设置 SMTPOptions 中的 ssl 选项,因为更新的 PHP 版本会自动处理 TLS 连接。删除以下代码:
$mail->SMTPOptions = array(
   'ssl' => array(
   'verify_peer' => false,
   'verify_peer_name' => false,
   'allow_self_signed' => true
   )
);
  • 错误日志: 如果升级后仍然遇到问题,请检查 PHP 错误日志和 PHPMailer 调试输出,以获取更多详细信息。
  • 密码安全: 避免在代码中直接硬编码密码。建议使用环境变量或配置文件来存储敏感信息。
  • STARTTLS 或 SMTPS: 推荐使用 PHPMailer::ENCRYPTION_STARTTLS,因为它在连接后才开始加密,而 PHPMailer::ENCRYPTION_SMTPS 会立即开始加密,可能与某些服务器不兼容。

总结

通过更新 PHP 版本,可以解决 PHPMailer 与 Office365 SMTP 服务器的连接问题,确保邮件发送功能正常运行。在升级过程中,请务必注意备份、兼容性和安全性,并根据实际情况进行调整。 如果问题仍然存在,请仔细检查错误日志和 PHPMailer 调试输出,以便更好地定位问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

248

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

522

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

610

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

714

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3619

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

56

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

72

2026.01.13

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.7万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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