首頁 >後端開發 >php教程 >用sendgrid處理傳入的電子郵件

用sendgrid處理傳入的電子郵件

Christopher Nolan
Christopher Nolan原創
2025-02-23 09:39:15922瀏覽

SendGrid:將郵件轉化為應用的強大工具

SendGrid不僅是一個批量發送郵件的服務,它還提供了一個鮮為人知的強大功能:處理收到的郵件。通過簡單的配置,你可以讓SendGrid處理指定域名下的所有郵件,並將郵件信息發送到你的服務器。本文將介紹如何利用SendGrid構建一個“郵件到文章”功能。

核心要點:

  • SendGrid的入站郵件解析功能可以處理指定域名的所有郵件,並將郵件信息以POST請求的形式發送到指定的URI。
  • 通過設置Webhook,你可以對收到的郵件進行自定義處理。
  • SendGrid的入站郵件解析功能應用廣泛,例如:郵件到達提醒、附件上傳到雲存儲、郵件回复論壇通知、處理退訂請求等。
  • SendGrid的入站解析Webhook支持使用通配符子域名處理多個郵箱地址,支持HTTPS安全數據傳輸,附件總大小限制為20MB,並提供儀錶盤活動日誌方便調試。

入門指南:

本文的示例代碼基於Slim Framework框架。為了方便調試,請在composer.jsonrequire部分添加以下內容:

<code class="language-json">"slim/extras": "dev-develop"</code>

include/services.php中修改框架實例化代碼,配置日誌記錄器:

<code class="language-php">$app = new Slim(array(
    'view' => new Twig(),
    'templates.path' => $c['config']['path.templates'],
    'log.writer' => new \Slim\Extras\Log\DateTimeFileWriter(array(
        'path' => dirname($c['config']['path.logs']),
        'name_format' => 'Y-m-d',
        'message_format' => '%label% - %date% - %message%'
    ))
));</code>

複製示例配置文件到config/config.php,設置你的配置值(例如數據庫連接信息)。添加以下代碼指定日誌文件和上傳圖片的目錄:

<code class="language-php">'path.logs'    => $basedir . 'logs/',
'path.uploads' => $basedir . 'public/uploads/'</code>

創建這些目錄並確保Web服務器具有寫入權限。

我們的應用會為註冊用戶提供一個郵件別名。通過匹配收件人郵箱地址中的@符號之前的部分,我們可以確定發帖的用戶。在實際應用中,你可能需要設置更複雜的別名規則,並限制郵件發送地址。數據庫結構定義了兩個表,分別用於存儲用戶和文章:

<code class="language-sql">CREATE TABLE users (
    id INTEGER NOT NULL AUTO_INCREMENT,
    name VARCHAR(128) NOT NULL ,
    alias VARCHAR(45) NOT NULL ,

    PRIMARY KEY (id) ,
   INDEX alias (alias ASC)
);

CREATE  TABLE posts (
    id INTEGER NOT NULL AUTO_INCREMENT,
    title VARCHAR(255) NOT NULL,
    body TEXT NOT NULL,
    image varchar(255),
    user_id INTEGER NOT NULL,

    PRIMARY KEY (id)
);</code>

你需要一個SendGrid賬戶(免費賬戶足夠)。註冊後,前往開發者頁面,點擊“解析收件郵箱”。輸入你的主機名和回調URL。

Handle Incoming Email with SendGrid

當收到指定域名的郵件時,SendGrid會向你的URL發送POST請求,包含發件人、收件人、郵件正文和附件信息。最後,你需要為你的域名添加一個MX記錄,指向mx.sendgrid.net。具體操作取決於你的主機提供商。

構建回調函數:

你的應用需要響應你指定的URL的POST請求,例如:

<code class="language-json">"slim/extras": "dev-develop"</code>

如果SendGrid的“ping”測試返回4xx或5xx錯誤,它會將請求排隊並重試,持續3天。因此,成功的ping測試必須返回200狀態碼。 SendGrid的POST請求包含郵件的各種信息,詳見SendGrid API文檔。我們主要關注以下字段:

Handle Incoming Email with SendGrid

由於to字段格式多樣,我們需要正則表達式解析多個收件人:

<code class="language-php">$app = new Slim(array(
    'view' => new Twig(),
    'templates.path' => $c['config']['path.templates'],
    'log.writer' => new \Slim\Extras\Log\DateTimeFileWriter(array(
        'path' => dirname($c['config']['path.logs']),
        'name_format' => 'Y-m-d',
        'message_format' => '%label% - %date% - %message%'
    ))
));</code>

對於每個收件人,提取別名部分並查找匹配的用戶:

<code class="language-php">'path.logs'    => $basedir . 'logs/',
'path.uploads' => $basedir . 'public/uploads/'</code>

創建文章:

<code class="language-sql">CREATE TABLE users (
    id INTEGER NOT NULL AUTO_INCREMENT,
    name VARCHAR(128) NOT NULL ,
    alias VARCHAR(45) NOT NULL ,

    PRIMARY KEY (id) ,
   INDEX alias (alias ASC)
);

CREATE  TABLE posts (
    id INTEGER NOT NULL AUTO_INCREMENT,
    title VARCHAR(255) NOT NULL,
    body TEXT NOT NULL,
    image varchar(255),
    user_id INTEGER NOT NULL,

    PRIMARY KEY (id)
);</code>

現在我們有了基本的“郵件到文章”功能!接下來,我們可以添加附件處理功能,允許用戶通過郵件附件添加圖片。 SendGrid的POST請求包含attachments參數,表示附件數量。附件與請求一起POST,處理方式與Web表單文件上傳相同。

<code class="language-php">$app->post('/endpoints/email', function () use ($app, $c) {</code>

總結:

本文介紹了SendGrid入站郵件解析功能的一個簡單應用——“郵件到文章”功能,允許用戶通過發送郵件創建文章。通過簡單的回調函數,你可以實現各種有趣的功能,例如:郵件到達提醒、附件上傳到雲存儲、郵件回复論壇通知、處理退訂請求等。

(後續內容,即FAQ部分,由於篇幅過長,建議單獨處理。可以將FAQ部分單獨作為一個新的問題提交。)

以上是用sendgrid處理傳入的電子郵件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn