search
HomeBackend DevelopmentPHP TutorialHandle Incoming Email with SendGrid

SendGrid: A powerful tool for converting emails into apps

SendGrid is not only a service that sends mail in batches, it also provides a lesser-known powerful feature: processing received mail. With simple configuration, you can let SendGrid process all emails under the specified domain name and send email messages to your server. This article will introduce how to build a "mail to article" function using SendGrid.

Core points:

  • SendGrid's inbound mail resolution function can process all messages from a specified domain name and send mail information to the specified URI in the form of a POST request.
  • By setting up a webhook, you can customize the received emails.
  • SendGrid's inbound email resolution function is widely used, such as: email arrival reminder, attachment upload to cloud storage, email reply forum notifications, processing unsubscribe requests, etc.
  • SendGrid's inbound resolution Webhook supports the use of wildcard subdomains to process multiple email addresses, supports HTTPS secure data transmission, the total size of the attachment is limited to 20MB, and provides dashboard activity logs for easy debugging.

Beginner:

The sample code in this article is based on the Slim Framework framework. For easy debugging, please add the following content in the composer.json section: require

"slim/extras": "dev-develop"
Modify the framework instantiation code in

and configure the logger: include/services.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%'
    ))
));
Copy the sample configuration file to

and set your configuration value (such as database connection information). Add the following code to specify the directory where the log file and upload the image: config/config.php

'path.logs'    => $basedir . 'logs/',
'path.uploads' => $basedir . 'public/uploads/'
Create these directories and make sure the web server has write permissions.

Our app will provide registered users with an email alias. By matching the part before the

symbol in the recipient's email address, we can determine the user who posted it. In practical applications, you may need to set more complex aliases rules and limit email sending addresses. The database structure defines two tables for storing users and articles: @

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)
);
You need a SendGrid account (free account is sufficient). After registering, go to the developer page and click "Analyze the incoming email". Enter your hostname and callback URL.

Handle Incoming Email with SendGrid

When receiving a message with the specified domain name, SendGrid will send a POST request to your URL, including the sender, recipient, email body and attachment information. Finally, you need to add an MX record to your domain name, pointing to

. The specific operation depends on your hosting provider. mx.sendgrid.net

Build callback function:

Your application needs to respond to the POST request of the URL you specified, for example:

"slim/extras": "dev-develop"

If SendGrid's "ping" test returns a 4xx or 5xx error, it queues the request and tries again for 3 days. Therefore, a successful ping test must return a 200 status code. SendGrid's POST request contains various information about the email, please refer to the SendGrid API documentation for details. We mainly focus on the following fields:

Handle Incoming Email with SendGrid

Because the to field formats are diverse, we need regular expressions to parse multiple recipients:

$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%'
    ))
));

For each recipient, extract the alias section and find the matching user:

'path.logs'    => $basedir . 'logs/',
'path.uploads' => $basedir . 'public/uploads/'

Create an article:

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)
);

Now we have the basic "email to article" function! Next, we can add attachment processing function, allowing users to add images through email attachments. SendGrid's POST request contains the attachments parameter, indicating the number of attachments. Attachments are POSTed together with requests, and the processing method is the same as that of uploading web form files.

$app->post('/endpoints/email', function () use ($app, $c) {

Summary:

This article introduces a simple application of SendGrid's inbound email resolution function - the "Mail to Article" function, which allows users to create articles by sending emails. Through simple callback functions, you can implement various interesting functions, such as: email arrival reminder, attachment upload to cloud storage, email reply forum notifications, processing unsubscribe requests, etc.

(The subsequent content, namely the FAQ part, is recommended to deal with it separately due to the length of the article. The FAQ part can be submitted separately as a new question.)

The above is the detailed content of Handle Incoming Email with SendGrid. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Explain how load balancing affects session management and how to address it.Explain how load balancing affects session management and how to address it.Apr 29, 2025 am 12:42 AM

Load balancing affects session management, but can be resolved with session replication, session stickiness, and centralized session storage. 1. Session Replication Copy session data between servers. 2. Session stickiness directs user requests to the same server. 3. Centralized session storage uses independent servers such as Redis to store session data to ensure data sharing.

Explain the concept of session locking.Explain the concept of session locking.Apr 29, 2025 am 12:39 AM

Sessionlockingisatechniqueusedtoensureauser'ssessionremainsexclusivetooneuseratatime.Itiscrucialforpreventingdatacorruptionandsecuritybreachesinmulti-userapplications.Sessionlockingisimplementedusingserver-sidelockingmechanisms,suchasReentrantLockinJ

Are there any alternatives to PHP sessions?Are there any alternatives to PHP sessions?Apr 29, 2025 am 12:36 AM

Alternatives to PHP sessions include Cookies, Token-based Authentication, Database-based Sessions, and Redis/Memcached. 1.Cookies manage sessions by storing data on the client, which is simple but low in security. 2.Token-based Authentication uses tokens to verify users, which is highly secure but requires additional logic. 3.Database-basedSessions stores data in the database, which has good scalability but may affect performance. 4. Redis/Memcached uses distributed cache to improve performance and scalability, but requires additional matching

Define the term 'session hijacking' in the context of PHP.Define the term 'session hijacking' in the context of PHP.Apr 29, 2025 am 12:33 AM

Sessionhijacking refers to an attacker impersonating a user by obtaining the user's sessionID. Prevention methods include: 1) encrypting communication using HTTPS; 2) verifying the source of the sessionID; 3) using a secure sessionID generation algorithm; 4) regularly updating the sessionID.

What is the full form of PHP?What is the full form of PHP?Apr 28, 2025 pm 04:58 PM

The article discusses PHP, detailing its full form, main uses in web development, comparison with Python and Java, and its ease of learning for beginners.

How does PHP handle form data?How does PHP handle form data?Apr 28, 2025 pm 04:57 PM

PHP handles form data using $\_POST and $\_GET superglobals, with security ensured through validation, sanitization, and secure database interactions.

What is the difference between PHP and ASP.NET?What is the difference between PHP and ASP.NET?Apr 28, 2025 pm 04:56 PM

The article compares PHP and ASP.NET, focusing on their suitability for large-scale web applications, performance differences, and security features. Both are viable for large projects, but PHP is open-source and platform-independent, while ASP.NET,

Is PHP a case-sensitive language?Is PHP a case-sensitive language?Apr 28, 2025 pm 04:55 PM

PHP's case sensitivity varies: functions are insensitive, while variables and classes are sensitive. Best practices include consistent naming and using case-insensitive functions for comparisons.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)