OsCommerce supports the use of SMTP to send email, but does not allow specification of a username and password for outgoing authentication, which is required when sending mail from our servers.

If you are on a server that does not allow the PHP mail() function or you just wish to use SMTP to send mail, this guide will walk you through how to set up SMTP with your shopping cart.

It is best to use an email address that you created in your cPanel on our server for the SMTP setup, but you can use your outgoing email settings for most other mail providers to send emails.

First thing to do is log in to the administrative panel, then go to Configuration ~> Email options and choose "SMTP" as the Transport Method.

Also verify these other settings:

Email Line Feels: LF
Use MIME EMail when sending email: YES
Verify E-Mail Addresses Through DNS : FALSE
Use MIME HTML When Sending Emails: FALSE

Also check the the General Store configuration to see that the Email Address and Email From fields are the same as the outgoing email address you'll be using for the setup.

You'll need to install a 3rd party script called phpMailer. As with any other time, please make a backup copy of any files you are changing in case something goes wrong!

To install phpMailer:

1. Download a copy of phpMailer

2. There are two files, class.phpmailer.php and class.smtp.php. Open the FTP site to the OScommerce installation, then upload them both into these folders:


3. There are two files in OsCommerce that you need to edit:


In the email.php file, locate this section: (line 519)

if (EMAIL_TRANSPORT == 'smtp') {
return mail($to_addr, $subject, $this->output, 'From: ' . $from . $this->lf . 'To: ' . $to . $this-> lf . implode($this->lf, $$
} else {
return mail($to, $subject, $this->output, 'From: '.$from.$this->lf.implode($this->lf, $this->headers).$this->lf.implode($this$

You'll need to comment out some of these lines, so they look like this:

if (EMAIL_TRANSPORT == 'smtp') {
// return mail($to_addr, $subject, $this->output, 'From: ' . $from . $this->lf . 'To: ' . $to . $this->lf . implode($this->lf, $$
// } else {
// return mail($to, $subject, $this->output, 'From: '.$from.$this->lf.implode($this->lf, $this->headers).$this->lf.implode($this$
// }
// }

Then copy and paste this code directly below those lines. Be sure to change the Host, Username, and Password fields to match the outgoing mail server.  When sending from our systems, please just use 'localhost' as the host, and your entire email address as the username.

require_once(DIR_WS_CLASSES . "class.phpmailer.php");
$pMail = new PHPMailer(); >$pMail->From = $from_addr;
$pMail->FromName = $from_name;
$pMail->Host = "mail.yourdomain.com"; // replace with your smtp server
$pMail->Username = "email@yourdomain.com"; // replace with your smtp username (if SMTPAuth is true)
$pMail->Password = "password"; // replace with your smtp password (if SMTPAuth is true)
$pMail->SMTPAuth = true; // true/false - turn on/off smtp authentication
$pMail->Subject = $subject;
$pMail->Body = $this->output;
$pMail->AddAddress($to_addr, $to_name);
return $pMail->Send();

This needs to be done for both email.php files in order to get the user-side and backend emailing to work. There is a sample email.php available here:


Continued Education in Course 105: Testing the osCommerce site
You are viewing Section 1: Setting up SMTP with osCommerce
Section 2: Sending out email in osCommerce Video
Did you find this article helpful?

We value your feedback!

Why was this article not helpful? (Check all that apply)
The article is too difficult or too technical to follow.
There is a step or detail missing from the instructions.
The information is incorrect or out-of-date.
It does not resolve the question/problem I have.
How did you find this article?
Please tell us how we can improve this article:
Email Address

new! - Enter your name and email address above and we will post your feedback in the comments on this page!

Support Center Login

Social Media Login

Related Questions

Here are a few questions related to this article that our customers have asked:
Ooops! It looks like there are no questions about this page.
Would you like to ask a question about this page? If so, click the button below!
Ask a Question
n/a Points
2014-07-28 10:51 am

In the second line of the Paste in code there is a mistake.

$pMail = new PHPMailer(); >$pMail->From = $from_addr;

should be changed to

$pMail = new PHPMailer();

$pMail->From = $from_addr; 

Post a Comment

Email Address:
Phone Number:

Please note: Your name and comment will be displayed, but we will not show your email address.

1 Questions & Comments

Post a comment

Back to first comment | top

Need more Help?


Ask the Community!

Get help with your questions from our community of like-minded hosting users and InMotion Hosting Staff.

Current Customers

Chat: Click to Chat Now E-mail: support@InMotionHosting.com
Call: 888-321-HOST (4678) Ticket: Submit a Support Ticket

Not a Customer?

Get web hosting from a company that is here to help. Sign up today!