View Categories

Sending Email with PHP from an SMTP Server

3 min read

Sending Email with PHP from an SMTP Server : #

$from = “someonelse@example.com”;
$headers = “From:” . $from;
echo mail (“borutflis1@gmail.com” ,”testmailfunction” , “Oj”,$headers);
I have trouble sending email in PHP. I get an error: SMTP server response: 530 SMTP authentication is required.

I was under the impression that you can send email without SMTP to verify. I know that this mail will propably get filtered out, but that doesn’t matter right now.

[mail function]
; For Win32 only.
; http://php.net/smtp
SMTP = localhost
; http://php.net/smtp-port
smtp_port = 25

; For Win32 only.
; http://php.net/sendmail-from
sendmail_from = someonelse@example.com
This is the setup in the php.ini file. How should I set up SMTP? Are there any SMTP servers that require no verification or must I setup a server myself?

Here is Some Solutions :

Solution 1: #

$mail = new PHPMailer();

// Settings
$mail->IsSMTP();
$mail->CharSet = ‘UTF-8’;

$mail->Host = “mail.example.com”; // SMTP server example
$mail->SMTPDebug = 0; // enables SMTP debug information (for testing)
$mail->SMTPAuth = true; // enable SMTP authentication
$mail->Port = 25; // set the SMTP port for the GMAIL server
$mail->Username = “username”; // SMTP account username example
$mail->Password = “password”; // SMTP account password example

// Content
$mail->isHTML(true); // Set email format to HTML
$mail->Subject = ‘Here is the subject’;
$mail->Body = ‘This is the HTML message body <b>in bold!</b>’;
$mail->AltBody = ‘This is the body in plain text for non-HTML mail clients’;

$mail->send();

Solution 2: #

<?php
ini_set(“SMTP”, “aspmx.l.google.com”);
ini_set(“sendmail_from”, “YOURMAIL@gmail.com”);

$message = “The mail message was sent with the following mail setting:\r\nSMTP = aspmx.l.google.com\r\nsmtp_port = 25\r\nsendmail_from = YourMail@address.com”;

$headers = “From: YOURMAIL@gmail.com”;

mail(“Sending@provider.com”, “Testing”, $message, $headers);
echo “Check your email now….&lt;BR/>”;
?>

Solution 3: #

<?php
$a1 = [‘monday@gmail.com’];
$r1 = fopen(‘a.txt’, ‘r’);
$r2 = curl_init(‘smtps://smtp.gmail.com’);
curl_setopt($r2, CURLOPT_MAIL_RCPT, $a1);
curl_setopt($r2, CURLOPT_NETRC, true);
curl_setopt($r2, CURLOPT_READDATA, $r1);
curl_setopt($r2, CURLOPT_UPLOAD, true);
curl_exec($r2);

Solution 4: #

//Import PHPMailer classes into the global namespace
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\SMTP;
use PHPMailer\PHPMailer\OAuth;
//Alias the League Google OAuth2 provider class
use League\OAuth2\Client\Provider\Google;

//SMTP needs accurate times, and the PHP time zone MUST be set
//This should be done in your php.ini, but this is how to do it if you don’t have access to that
date_default_timezone_set(‘Etc/UTC’);

//Load dependencies from composer
//If this causes an error, run ‘composer install’
require ‘../vendor/autoload.php’;

//Create a new PHPMailer instance
$mail = new PHPMailer();

//Tell PHPMailer to use SMTP
$mail->isSMTP();

//Enable SMTP debugging
//SMTP::DEBUG_OFF = off (for production use)
//SMTP::DEBUG_CLIENT = client messages
//SMTP::DEBUG_SERVER = client and server messages
$mail->SMTPDebug = SMTP::DEBUG_SERVER;

//Set the hostname of the mail server
$mail->Host = ‘smtp.gmail.com’;

//Set the SMTP port number:
// – 465 for SMTP with implicit TLS, a.k.a. RFC8314 SMTPS or
// – 587 for SMTP+STARTTLS
$mail->Port = 465;

//Set the encryption mechanism to use:
// – SMTPS (implicit TLS on port 465) or
// – STARTTLS (explicit TLS on port 587)
$mail->SMTPSecure = PHPMailer::ENCRYPTION_SMTPS;

//Whether to use SMTP authentication
$mail->SMTPAuth = true;

//Set AuthType to use XOAUTH2
$mail->AuthType = ‘XOAUTH2’;

//Fill in authentication details here
//Either the gmail account owner, or the user that gave consent
$email = ‘someone@gmail.com’;
$clientId = ‘RANDOMCHARS—–duv1n2.apps.googleusercontent.com’;
$clientSecret = ‘RANDOMCHARS—–lGyjPcRtvP’;

//Obtained by configuring and running get_oauth_token.php
//after setting up an app in Google Developer Console.
$refreshToken = ‘RANDOMCHARS—–DWxgOvPT003r-yFUV49TQYag7_Aod7y0’;

//Create a new OAuth2 provider instance
$provider = new Google(
[
‘clientId’ => $clientId,
‘clientSecret’ => $clientSecret,
]
);

//Pass the OAuth provider instance to PHPMailer
$mail->setOAuth(
new OAuth(
[
‘provider’ => $provider,
‘clientId’ => $clientId,
‘clientSecret’ => $clientSecret,
‘refreshToken’ => $refreshToken,
‘userName’ => $email,
]
)
);

//Set who the message is to be sent from
//For gmail, this generally needs to be the same as the user you logged in as
$mail->setFrom($email, ‘First Last’);

//Set who the message is to be sent to
$mail->addAddress(‘someone@gmail.com’, ‘John Doe’);

//Set the subject line
$mail->Subject = ‘PHPMailer GMail XOAUTH2 SMTP test’;

//Read an HTML message body from an external file, convert referenced images to embedded,
//convert HTML into a basic plain-text alternative body
$mail->CharSet = PHPMailer::CHARSET_UTF8;
$mail->msgHTML(file_get_contents(‘contentsutf8.html’), __DIR__);

//Replace the plain text body with one created manually
$mail->AltBody = ‘This is a plain-text message body’;

//Attach an image file
$mail->addAttachment(‘images/phpmailer_mini.png’);

//send the message, check for errors
if (!$mail->send()) {
echo ‘Mailer Error: ‘ . $mail->ErrorInfo;
} else {
echo ‘Message sent!’;
}

Powered by BetterDocs

Leave a Reply

Your email address will not be published. Required fields are marked *

Privacy Settings
We use cookies to enhance your experience while using our website. If you are using our Services via a browser you can restrict, block or remove cookies through your web browser settings. We also use content and scripts from third parties that may use tracking technologies. You can selectively provide your consent below to allow such third party embeds. For complete information about the cookies we use, data we collect and how we process them, please check our Privacy Policy
Youtube
Consent to display content from Youtube
Vimeo
Consent to display content from Vimeo
Google Maps
Consent to display content from Google
Spotify
Consent to display content from Spotify
Sound Cloud
Consent to display content from Sound