通过 PHP 读取微软邮箱(Outlook/Office 365 邮箱)

通过 PHP 读取微软邮箱Outlook/Office 365 邮箱)邮件,通常需要使用 Microsoft Graph API,因为微软逐步淘汰了基于用户名和密码的 IMAP/SMTP 方式。Microsoft Graph API 支持 OAuth2.0 认证,可以安全地访问和管理用户邮件。

以下是实现读取微软邮箱邮件的完整示例。

实现步骤

1. 准备工作

1.1 注册 Azure 应用

  1. 登录到 Azure Portal
  2. 转到 Azure Active Directory > 应用注册 > 新注册
  3. 填写以下信息:
    • 名称:填写你的应用名称。
    • 支持的帐户类型:选择适合的帐户类型(如组织和个人)。
    • 重定向 URI:设置为 http://localhost 或你的回调地址。
  4. 点击 注册 完成。

1.2 配置 API 权限

  1. 选择刚刚注册的应用,在 API 权限 中,添加以下权限:
    • Microsoft Graph > Mail.Read(读取邮件)。
    • Microsoft Graph > offline_access(获取刷新令牌)。
  2. 点击 授予管理员同意,确保权限被激活。

1.3 获取应用的客户端 ID 和密钥

  1. 转到 证书和密钥,生成新的客户端密钥,并保存密钥值(只显示一次)。
  2. 记录以下信息:
    • 应用(客户端)ID
    • 目录(租户)ID
    • 客户端密钥

2. 安装必要的 PHP 包

使用 Microsoft Graph PHP SDK 或直接调用 REST API。推荐使用 league/oauth2-client 库进行 OAuth2.0 授权。

安装依赖

composer require league/oauth2-client
composer require microsoft/microsoft-graph

3. PHP 示例代码

以下代码实现了授权和读取邮件:

3.1 获取 OAuth 令牌

<?php
require 'vendor/autoload.php';

use League\OAuth2\Client\Provider\GenericProvider;

// 配置 OAuth2 客户端
$provider = new GenericProvider([
    'clientId'                => 'YOUR_CLIENT_ID',     // Azure 应用的客户端 ID
    'clientSecret'            => 'YOUR_CLIENT_SECRET', // Azure 应用的客户端密钥
    'redirectUri'             => 'http://localhost',   // 回调地址
    'urlAuthorize'            => 'https://login.microsoftonline.com/YOUR_TENANT_ID/oauth2/v2.0/authorize',
    'urlAccessToken'          => 'https://login.microsoftonline.com/YOUR_TENANT_ID/oauth2/v2.0/token',
    'urlResourceOwnerDetails' => '',
    'scopes'                  => 'Mail.Read offline_access'
]);

// 检查是否有授权码
if (!isset($_GET['code'])) {
    // 重定向到授权 URL
    $authorizationUrl = $provider->getAuthorizationUrl();
    session_start();
    $_SESSION['oauth2state'] = $provider->getState();
    header('Location: ' . $authorizationUrl);
    exit;
} elseif (empty($_GET['state']) || ($_GET['state'] !== $_SESSION['oauth2state'])) {
    // CSRF 检查失败
    unset($_SESSION['oauth2state']);
    exit('Invalid state');
}

// 获取访问令牌
$accessToken = $provider->getAccessToken('authorization_code', [
    'code' => $_GET['code']
]);

echo 'Access Token: ' . $accessToken->getToken();

3.2 读取邮件

通过 Microsoft Graph SDK 或直接调用 REST API 获取邮件。

<?php
require 'vendor/autoload.php';

use Microsoft\Graph\Graph;
use Microsoft\Graph\Model;

// 使用获取的 Access Token
$accessToken = 'YOUR_ACCESS_TOKEN'; // 从上一步获取

$graph = new Graph();
$graph->setAccessToken($accessToken);

// 获取邮件
try {
    $messages = $graph->createRequest("GET", "/me/messages")
        ->setReturnType(Model\Message::class)
        ->execute();

    foreach ($messages as $message) {
        echo "Subject: " . $message->getSubject() . PHP_EOL;
        echo "From: " . $message->getFrom()->getEmailAddress()->getAddress() . PHP_EOL;
        echo "Body Preview: " . $message->getBodyPreview() . PHP_EOL;
        echo "----------------------------------" . PHP_EOL;
    }
} catch (Exception $e) {
    echo "Error: " . $e->getMessage();
}

4. 调试和优化

  • 错误处理:捕获令牌过期或无效的异常,使用刷新令牌重新获取 Access Token。
  • 分页处理:邮件列表可能分页,使用 Graph API 的 @odata.nextLink 获取下一页数据。
  • 日志记录:记录请求和响应,便于调试。

5. 常见问题

  1. 授权失败:检查 Azure 应用的权限是否正确,确保授权 URL 和回调地址一致。
  2. 邮件读取为空:确保邮箱中有邮件,且正确授权了 Mail.Read 权限。
  3. 令牌过期:实现令牌的自动刷新,保存 refresh_token 并使用它请求新令牌。

通过上述步骤,您可以使用 PHP 读取微软邮箱的邮件。如果需要进一步功能(如发送邮件、管理日历),可以扩展使用 Microsoft Graph API 的相关端点。

发布者:myrgd,转载请注明出处:https://www.object-c.cn/4535

Like (0)
Previous 2024年11月25日 下午7:17
Next 2024年11月25日 下午7:30

相关推荐

  • Docker 部署 Navidrome 服务器与远程访问听歌的教程

    Navidrome 是一个轻量级、功能强大的音乐流媒体服务器,可以通过 Docker 容器方便地部署。本教程涵盖从本地部署到远程访问的详细步骤。 一、环境准备 1. 安装 Docker 和 Docker Compose 在服务器(或本地机器)上安装 Docker 和 Docker Compose。 安装 Docker Ubuntu 示例: CentOS 示例…

    2024年11月22日
    00
  • Python 的 json模块序列化数据从文件里读取出来或存入文件

    Python 的 json 模块用于处理 JSON 格式的数据,可以将 JSON 数据与 Python 数据结构之间相互转换。以下是具体用法,包括从文件读取 JSON 数据以及将数据写入文件: 1. 将 JSON 数据从文件中读取到 Python 数据结构 代码示例: 解析过程: 2. 将 Python 数据结构写入到文件中(序列化为 JSON) 代码示例:…

    2024年11月26日
    00
  • XiYan-SQL 是一种多生成器集成的 Text-to-SQL框架,专注于将自然语言查询转换为结构化查询语言

    XiYan-SQL 是一种多生成器集成的 Text-to-SQL(文本转 SQL)框架,专注于将自然语言查询转换为结构化查询语言(SQL),从而高效地与数据库交互。以下是该框架的主要特点、技术原理及其应用场景的解析: 1. XiYan-SQL 的核心特点 2. 核心技术原理 3. 应用场景 4. XiYan-SQL 的优势 5. 示例 输入: 自然语言查询:…

    2024年12月5日
    00
  • 在使用 uni-app 开发小程序或移动端应用时 title image失效问题

    在使用 uni-app 开发小程序或移动端应用时,若发现 分享的标题(title) 和 图片(image) 配置无效,可能是由于配置错误、平台限制或代码逻辑问题。以下是排查和解决问题的详细指南: 1. 确保正确使用分享 API onShareAppMessage(自定义转发) 确保在 pages 的页面代码中正确使用了 onShareAppMessage 方…

    2024年11月25日
    00
  • 远程仓库 ,从GitHub拉取代码失败的解决办法

    从GitHub拉取代码失败通常由以下几种原因引起:网络问题、认证失败、远程仓库配置错误等。以下是常见的失败场景及解决办法。 1. 网络问题症状连接超时。报错如:fatal: unable to access ‘https://github.com/…’: Failed to connect to github.com port 443: Connecti…

    2024年11月28日
    00
  • 在 Linux 系统上配置 Hadoop 环境,包括创建 hadoop 用户、更新 apt、安装 SSH 和配置 Java 环境

    以下是详细的步骤,用于在 Linux 系统上配置 Hadoop 环境,包括创建 hadoop 用户、更新 apt、安装 SSH 和配置 Java 环境。 1. 创建 Hadoop 用户创建一个名为 hadoop 的新用户: 根据提示设置密码和用户信息。 将 hadoop 用户添加到 sudo 组(可选): 切换到 hadoop 用户: 2. 更新 APT 包…

    2024年12月1日
    00
  • 在 .NET 8 框架中使用 Web API 项目并通过引用 SqlSugar ORM 来操作数据库

    在 .NET 8 框架中使用 Web API 项目并通过引用 SqlSugar ORM 来操作数据库,可以遵循以下步骤: 1. 准备工作确保已安装 .NET 8 SDK 和 SqlSugar NuGet 包。创建或打开现有的 Web Core API 项目。安装 SqlSugar NuGet 包: 2. 配置 SqlSugar在 Web API 项目中配置 …

    2024年11月27日
    00
  • 理解 HTML、HTML5 和 “H5” 区别的重要性

    HTML & HTML5 & H5 的区别在构建现代网页时,理解 HTML、HTML5 和 “H5” 的区别是非常重要的。以下是它们的概念和主要区别: 1. HTML(超文本标记语言)定义HTML 是 HyperText Markup Language 的缩写,即超文本标记语言,用于定义网页内容的结构和含义。特性提供基…

    2024年12月2日
    00
  • Apache Flink 分布式流处理框架中API的使用部分

    Apache Flink 是一个分布式流处理框架,支持批处理和流处理。在 Flink 中,API 是核心部分,允许用户定义数据流处理逻辑、配置作业并执行操作。Flink 提供了多种 API 来满足不同的需求,包括 DataStream API、DataSet API(批处理 API)、Table API 和 SQL API。1. Flink DataStre…

    2024年11月29日
    00
  • 微信支付域名回调用个人服务器域名的方法

    在使用微信支付功能时,微信支付的回调需要指定合法的 支付回调通知地址(即回调域名)。如果你想使用个人服务器的域名来作为微信支付的回调域名,需要满足以下条件并完成配置: 1. 域名要求 合法域名的要求 2. 配置个人服务器域名 步骤 1:准备域名 步骤 2:设置 HTTPS 步骤 3:配置域名解析 3. 微信支付后台配置 3. 保存配置。 4. 在代码中处理回…

    2024年11月24日
    00
  • 浏览器跨域请求中携带 Cookie需要同时在前端和后端进行配置

    浏览器跨域请求中,要让请求携带 Cookie,需要同时在前端和后端进行配置。以下是实现的方法: 前端配置 在前端代码中使用 fetch 或 Axios 发起请求时,需要设置 credentials 属性: 1. Fetch 示例 2. Axios 示例 后端配置 在后端需要允许跨域请求,并确保 Cookie 能够正常传递。 1. 设置 Access-Cont…

    2024年12月9日
    00
  • 微信小程序的 RequestTask.onChunkReceived 接口接收二进制数据流

    微信小程序的 RequestTask.onChunkReceived 接口允许接收分块的二进制数据流(如视频或音频流),但在小程序环境中,由于不支持 TextDecoder,处理这些数据时需要采用其他方法。 解析数据流的方案 模拟 TextDecoder 功能 如果需要将 ArrayBuffer 转换为字符串(如 UTF-8 编码),可以通过自定义方法模拟 …

    2024年11月26日
    00
  • 在github上提交PR(Pull Request) + 多个pr同时提交、互不干扰的方法

    在 GitHub 上提交 PR(Pull Request)是一种将代码变更合并到主分支或其他目标分支的常见方式。在同时处理多个 PR 时,需要使用独立的分支来避免相互干扰。以下是详细教程: 步骤一:单个 PR 的提交流程Fork 仓库如果没有直接访问权限,先 fork 原仓库到自己的 GitHub 帐号。在 fork 的仓库上操作自己的代码。克隆仓库到本地 …

    2024年11月26日
    00
  • 如何用pbootcmsAPI接口开发微信小程序UNIAPP

    使用 PbootCMS 的 API 接口结合 UniApp 开发微信小程序,可以实现高效的内容管理和展示。以下是一个完整的开发流程,包括 API 接口设置、小程序功能设计和开发细节。 1. 准备工作1.1 配置 PbootCMS API 接口PbootCMS 提供 API 功能,需在后台开启并配置:登录 PbootCMS 后台管理。前往 系统管理 -> AP…

    2024年11月28日
    00
  • 在使用 PHP 抓取 HTTPS 资源时,会遇到一些常见问题

    在使用 PHP 抓取 HTTPS 资源时,可能会遇到一些常见问题。这些问题通常与 SSL 配置、证书验证或 PHP 设置相关。以下是常见问题及其解决方法的汇总: 1. SSL 证书验证失败问题描述当使用 file_get_contents、cURL 等方法访问 HTTPS 资源时,可能会遇到类似以下错误: 解决方法更新 cacert.pem 文件下载最新的根…

    2024年12月2日
    00

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

在线咨询: QQ交谈

邮件:723923060@qq.com

关注微信