Neste procedimento iremos entender como enviar e-mails em massa dentro de nossos limites permitidos.

NOTAS:

  • O envio de e-mail em massa caracterizado como Spam é expressamente proibido em nossa rede. Para saber mais sobre nossa Política Antispam, acesse: Posso enviar Spam para divulgar o meu domínio?
  • Para preservar a capacidade de entrega de mensagens, não permitimos o envio de mensagens em massa com características consideradas maliciosas ou abusivas. Para saber mais sobre as práticas e conteúdos não permitidos no envio de e-mail em massa, acesse: Política para Envio de Emails em Massa
  • A seguir, apresentamos um exemplo de script PHP que faz o envio temporizador de 10 e-mails a cada 12 segundos, visando evitar o acúmulo de mensagens no Serviço de E-mail.

    Nota: Permitimos apenas envio autenticado (usuário e senha), mais informações acesse Como enviar email em PHP de forma autenticada no meu site?

    1. Crie o script PHP para enviar o envio dos e-mails, o arquivo deve se chamar mail_lotes.php

    <?php

    /**

    * This example shows how to send a message to a whole list of recipients efficiently.

    */

    require __DIR__.’/PHPMailer/Exception.php’;

    require __DIR__.’/PHPMailer/PHPMailer.php’;

    require __DIR__.’/PHPMailer/SMTP.php’;

    use PHPMailer\PHPMailer\PHPMailer;

    use PHPMailer\PHPMailer\SMTP;

    use PHPMailer\PHPMailer\Exception;

    error_reporting(E_STRICT | E_ALL);

    date_default_timezone_set(‘Etc/UTC’);

    //Passing `true` enables PHPMailer exceptions

    $mail = new PHPMailer(true);

    $body =’oooooooooooo’; //file_get_contents(‘contents.html’);

    $mail->isSMTP();

    $mail->Host = ‘smtp.dominio.com.br’;

    $mail->SMTPAuth = true;

    $mail->SMTPKeepAlive = true; //SMTP connection will not close after each email sent, reduces SMTP overhead

    $mail->Port = 587;

    $mail->Username = ‘suaconta@seudominio.com.br’;

    $mail->Password = ‘suasenha’;

    $mail->setFrom(‘suaconta@seudominio.com.br’, ‘List manager’);

    //$mail->addReplyTo(‘list@example.com’, ‘List manager’);

    $mail->Subject = ‘PHPMailer Simple database mailing list test’;

    //Same body for all messages, so set this before the sending loop

    //If you generate a different body for each recipient (e.g. you’re using a templating system),

    //set it inside the loop

    $mail->msgHTML($body);

    //msgHTML also sets AltBody, but if you want a custom one, set it afterwards

    $mail->AltBody = ‘To view the message, please use an HTML compatible email viewer!’;

    //Connect to the database and select the recipients from your mailing list that have not yet been sent to

    //You’ll need to alter this to match your database

    $mysql = mysqli_connect(‘localhost’, ‘nameuser’, ‘senhabanco’);

    mysqli_select_db($mysql, ‘namedatabase’);

    $result = mysqli_query($mysql, ‘SELECT full_name, email, photo FROM mailinglist WHERE sent = FALSE’);

    foreach ($result as $row) {

    try {

    $mail->addAddress($row[‘email’], $row[‘full_name’]);

    } catch (Exception $e) {

    echo ‘Invalid address skipped: ‘ . htmlspecialchars($row[‘email’]) . ‘<br>’;

    continue;

    }

    if (!empty($row[‘photo’])) {

    //Assumes the image data is stored in the DB

    $mail->addStringAttachment($row[‘photo’], ‘YourPhoto.jpg’);

    }

    try {

    $mail->send();

    echo ‘Message sent to :’ . htmlspecialchars($row[‘full_name’]) . ‘ (‘ .

    htmlspecialchars($row[‘email’]) . ‘)<br>’;

    //Mark it as sent in the DB

    mysqli_query(

    $mysql,

    “UPDATE mailinglist SET sent = TRUE WHERE email = ‘” .

    mysqli_real_escape_string($mysql, $row[‘email’]) . “‘”

    );

    } catch (Exception $e) {

    echo ‘Mailer Error (‘ . htmlspecialchars($row[‘email’]) . ‘) ‘ . $mail->ErrorInfo . ‘<br>’;

    //Reset the connection to abort sending this message

    //The loop will continue trying to send to the rest of the list

    $mail->getSMTPInstance()->reset();

    }

    //Clear all addresses and attachments for the next iteration

    $mail->clearAddresses();

    $mail->clearAttachments();

    }

    $seconds = 12;

    echo(“<meta http-equiv=”refresh” content=”” . $seconds . “”>”);

    ?>

    Notas:: exemplo realizado na versão 8.1 do php

    • Substitua Conta@SeuDomínio por um endereço de e-mail válido de seu domínio, mysql.SeuDomínio pelo endereço do seu banco de dados, usuario pelo login de acesso ao MySQL e pela senha de acesso ao MySQL.

    2º Passo: Publicação do arquivo:

    Através de uma ferramenta de FTP, publique o arquivo mail_lotes.php na raiz do seu domínio ou em um diretório de sua preferência.

    AVISO LEGAL: Os procedimentos descritos neste documento devem ser executados de acordo com o contexto de cada sistema, de forma a evitar impactos negativos à segurança, disponibilidade, integridade e privacidade de dados. A CentralServer se reserva o direito de modificar a qualquer tempo e sem aviso prévio as informações aqui apresentadas a fim de refletir o lançamento de novos serviços, atualizações físicas e operacionais, e evolução do estado-da-arte da tecnologia.