Send HTML Emails with the PHP PEAR Mail Library

Sending emails in HTML format within your web applications is a necessity. Whether you're a blog with marketing and newsletter subscription needs or a full-fledged eCommerce site handling transactional data, you'll need functionality behind it to submit emails successfully to all your users.

This article walks you through setting up the PEAR Mail library within your PHP installation on a Ubuntu server, adding the ability to send HTML emails via SMTP.  It will also teach you how to add multiple recipients as well as add attachments to your emails.

What is PEAR?

Simply put, PEAR, or PHP Extension Application Repository for short, is a repository of PHP software code and libraries.

PHP prides itself on providing a solid functionality case while also maintaining its lightweight architecture. However, there are some instances where you can expand on that pre-built functionality.

In the event of sending HTML emails with PHP, PEAR is a perfect solution.

How to Install PEAR and the PEAR Mail Library

Assuming you already have PHP installed on a Ubuntu instance, let's start with adding onto it with a PEAR installation.

Open up your command-line tool and enter the following command to update your server to the latest packages:

sudo apt-get update

Now that your packages are updated, let's install PEAR for PHP:

sudo apt-get install php-pear

Now, if you type pear in your command-line tool and press the Enter key, you should see a list of available commands within PEAR. If you don't, something is wrong with your installation and you'll need to troubleshoot.

The final step for your PEAR installation is to setup PEAR to use the Mail library by entering this command:

pear install --alldeps Mail

And, if you'll be adding attachments to your emails, make sure to also install the Mail_Mime extension:

pear install Mail_Mime

In the rest of the article, we'll go through each of the steps to configure and submit custom emails to your website users, as well as best practices to follow when submitting emails.

1. Include the PEAR Mail Library

Now we'll concentrate on creating the PHP script in your application.

First, you'll need to include the newly installed PEAR Mail library with the following line of code:

require_once "Mail.php";

You do not need to modify the include path for this library to work. Doing so generally throws an exception. Simply including as "Mail.php" will work anywhere within your web application.

If you'll be adding attachments to your emails, you'll also need to include the following mime.php library file:

require_once "Mail/mime.php";

2. Set your Email Headers

Second, we'll need to define a set of headers in an array:

$headers = [
"From" => "hello@orangeable.com",
"To" => "hello@orangeable.com",
"Reply-To" => "hello@orangeable.com",
"Subject" => "Test Email",
"Content-Type" => "text/html"
];

Here, we're defining the from and to email addresses for the email submission, as well as the correct address to reply to. And we're including a custom subject line so the email subject isn't blank when users receive it.

We're also including the content type of the email. The default is plain text, so if you want to send emails containing HTML content, you'll need to change the content type to "text/html".

If you would like to copy additional recipients to this email, you can do so with either the Cc or Bcc attributes within the $headers object.  In doing so, just make sure that you're providing a comma-delimited list of email addresses like this:

$headers["Cc"] = "email@one.com,email@two.com";
$headers["Bcc"] = "email@one.com,email@two.com";

3. Configure your SMTP Settings

Third, we need to configure our SMTP variables by setting two arguments in the Mail::factory method.

$stmp = Mail::factory(
"smtp",
[
"host" => "my.smtp.host",
"username" => "smtp-username",
"password" => "smtp-password",
"port" => 587,
"auth" => true,
"html" => true
]
);

Here, we're assigning the $stmp variable to our Mail::factory() object, readying it for email submission in the next step.

The first argument is set to the value "smtp" because we'll be sending emails via an SMTP server. The second argument is an array, defining our SMTP server settings.

You'll just need to make sure that you change out your variable assignments to the correct values that match your SMTP server settings.

If you don't know your SMTP server settings, check with your hosting provider. Most hosting providers provide an SMTP server as part of their package as long as you're a customer with them.

4. Send an HTML Email

In the last step, we'll be sending our HTML email with the PEAR Mail library's Mail::send() method:

$body = '
<h1>This is a test email</h1>
<p>This is to test HTML within our emails.</p>
';

$mail = $stmp->send(
"hello@orangeable.com",
$headers,
$body
);

For the first argument of the Mail::send() method, we're attaching the email address, or addresses, we'll be sending our email to. The second argument is our $headers array we created earlier, and the final argument is our message body.

The message body can be in HTML format and you can include any styling methods you want within your emails, as long as your email styling abides by the guidelines.

Assigning a variable to your Mail::send() method is not required, but available to view and debug email submission responses from the SMTP server.

var_dump($mail);

5. Add Email Attachments

There is some additional code required if you'll be adding attachments to your emails:

$file = "[path-to-file]";
$mime = new Mail_mime();
$mime->setHTMLBody($body);
$mime->addAttachment($file, "application/octet-stream");<br>

We started by setting the path to the file we would like to attach to our email.  Then we invoke the Mail_mime() extension, save the HTML in our $body variable to the $mime object, then attach the file.

When attaching files, make sure to use the application/octet-stream MIME type.  This MIME type is used for unknown binary files and ensures that the file gets added to the email as a downloadable attachment instead of included in the body.

Next, we need to add the headers from our $mime object to our $headers object:

$body = $mime->get();
$headers = $mime->headers($headers);

Other Useful Tidbits

  • You can send email to multiple recipients at once by changing the to value in your $headers variable and first argument of the Mail::send() method to a comma-delimited list format of valid email addresses.
  • You can copy other users on email submissions by including the Cc and Bcc objects within the $headers variable, as explained earlier. If you want to copy multiple recipients at once, you can do so in a comma-delimited list format.
Bcc tends to be unreliable in older versions of the PEAR Mail library.  Make sure you're using the latest version on your server and test this option thoroughly. 
Important Note: Some hosting providers, like AWS' Simple Email Service, require that you verify your domains and email addresses before sending emails out. Check with your hosting provider to make sure that this is done properly before you start submitting emails through their servers.

Email Submission Best Practices

This isn't related to email submission functionality but should be mentioned to cover a few email etiquette points.

  • Make sure you clearly describe who you are and what you're presenting to your users in your emails. Sending garbage will result in complaints that could get you permanently banned by your SMTP server provider.
  • An email should only be submitted to users who are expecting it. Popular example types include when they've placed an order on your website, they should receive an order confirmation email. Or if they've signed up to your mailing list or newsletter, they would expect to receive updates from you via email on a regular basis.
  • In cases where you submit emails to users who have signed up for your newsletter or mailing list, you should always provide a way to unsubscribe from the distribution lists easily. Clearly displaying a link at the bottom of your email with the title "Unsubscribe" is a good way to handle this. Make sure this link works properly.

Conclusion

Now, you should be able to send HTML emails to all of your users and do it correctly. There's a little bit of setup involved, but it should only take a few minutes to get up and running when sending HTML emails with PHP PEAR.

This was the easiest implementation for my current setup. You're also able to use PHP's built-in mail() function, I just didn't find that it had all of the bells and whistles that come with the PHP PEAR Mail Library.

Written by: Josh Rowe

Last Updated: December 27, 2021
Created: October 19, 2020