Jump to content
violin101

Codeigniter - Como enviar múltiplos e-mails com PHPmailer

Recommended Posts

Caros amigos, saudações...

 

Desculpa recorrer ao grupo mas estou com uma dúvida e não sei como resolver.

 

Tenho uma Rotina onde consigo enviar e-mail usando phpmailer. O problema é que consigo enviar individualmente.

 

Preciso criar uma Rotina onde Busco no MySql todos os usuário que comprou um determinado produto (por exemplo: Notebook).

 

no MySql foi encontrado 10 usuários ou pode ser mais ou menos usuário.

 

Como faço para enviar e-mail a todos os usuários com uma mensagem de agradecimento ?

 

Grato,

 

Cesar

Share this post


Link to post
Share on other sites

Caros amigos

 

Li várias vezes o exemplos mencionado mas infelizmente não consegui entender.

 

Abaixo posto meu código que utilizo para enviar RESPOSTA de E-MAIL ===> individual.

<?php
 
class Contats extends CI_Controller{
    
    function __construct()
    {
        parent::__construct();
        if ((!session_id()) || (!$this->session->userdata('logado'))) {
            redirect('admin/login');
        }

            $this->load->helper(array('form', 'codegen_helper'));
            $this->load->model('admin/contats_model', '', true);

            $this->load->model('admin/controle_model');
            $this->data['usuario'] = $this->controle_model->getById($this->session->userdata('id'));
            $this->data['dados'] = $this->controle_model->getEmitente(); 
            $this->data['clients'] = $this->controle_model->getClientes($this->session->userdata('id'));
    }
    
    function index()
    {
        $this->gerenciar();
    }

    function gerenciar($id = null)
    {

        $this->data['results'] = $this->contats_model->get('contatos', 'idcontatos,nomecontato,emailcontato,asscontato,menscontato,respcontato,datarecebe,horarecebe,dataresposta,horaresposta,iduser', '', $id);   

        $this->load->view('admin/estilo/header', $this->data);           
        $this->load->view('admin/contats/contats');
        
    }

    //Função para responder Contato por e-mail
    function responder($id = null)
    {
        if ($this->input->post()) {

            //Recebe variáveis via POST
            $email = $this->input->post('mailCont');
            $retorno = $this->input->post('retorno');

            $dadoscont = $this->contats_model->buscaemail($email, $id);

            if ((isset($dadoscont)) && (!empty($dadoscont))) {
                $status = '';
  
                foreach ($dadoscont as $user) {
                    $nome = $user->nomecontato;
                    $asunt = $user->asscontato;
                    $mensag = $user->menscontato;
                    $status = $user->respcontato; 
                    $dtarec = date(('d/m/Y'), strtotime($user->datarecebe));
                    $hrsrec = date(('H:i:s'), strtotime($user->horarecebe));                                
                }

                if ($status != 2 ) {
                    error_reporting(E_ALL);
                    ini_set("display_Errors", 1);
                        
                    $this->load->library('email');
                        
                    $this->email->from('meuEmail@hotmail.com'); //o mesmo e-mail que estiver no config/email.php
                    $this->email->to($email);
                    $this->email->subject('Retorno: '.$asunt.'');
                    $this->email->message('<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
                                        <html xmlns="http://www.w3.org/1999/xhtml">
                                            <head>
                                                <meta charset="utf-8">
                                                <meta http-equiv="X-UA-Compatible" content="IE=edge">
                                                <meta http-equiv="content-language" content="pt-br" /> 
                                                <title>Teste de E-mail</title>
                                            </head>
                                            <body>
                                                <br/>'.$retorno.'<br/>
                                                <hr/><br/>
                                                De: '.$nome.'<br/>
                                                Enviado: '.$dtarec.' - '.$hrsrec.'<br/>
                                                E-mail: '.$email.'<br/>
                                                Assunto: '.$asunt.'<br/>
                                                <br/>'.$mensag.'<br/>
                                            </body>
                                        </html>');
         
                            if($this->email->send()){
                                $this->session->set_flashdata('success', 'Contato Respondido com sucesso!');
                                redirect(base_url() . 'admin/contats/responder/'.$this->input->post('idcontatos'));
                            } else {
                                $this->session->set_flashdata('error', 'Ocorreu um erro ao tentar Responder o Contato!');     
                                redirect(base_url() . 'admin/contats/responder/'.$this->input->post('idcontatos'));
                            }

                    } else {
                      $this->session->set_flashdata('error', 'Não foi possível enviar o e-mail!');
                      redirect(base_url() . 'admin/contats/responder/'.$this->input->post('idcontatos'));
                    }               

            } else {
              $this->session->set_flashdata('error', 'Este E-mail não existe!');
              redirect(base_url() . 'admin/contats/responder/'.$this->input->post('idcontatos'));
            }

        } else {

            $this->data['result'] = $this->contats_model->getById($id);

            $this->load->view('admin/estilo/header', $this->data);    
            $this->load->view('admin/contats/respondeContats'); 
        }  


    }  



}

 

O código acima envia resposta individual para cada contato que é uma Beleza.

 

Tentei de várias formas fazer o envio MÚLTIPLO mas não tive sucesso. 

 

Por favor, alguém teria algum exemplo nesse assunto. Os tema de leitura que os amigos me indicou não consegui entender.

 

Grato,

 

Cesar

Share this post


Link to post
Share on other sites

Aqui vai bem comentado cada opção

Acredito que vai entender agora

 

<?php
// Conexão com banco de dados MySQL
define('BD_USER', 'usuario');
define('BD_PASS', 'senha');
define('BD_NAME', 'base_de_dados');
mysql_connect('IP_ou_localhost', BD_USER, BD_PASS);
mysql_select_db(BD_NAME);
?>

 

<?php
// Inclui o arquivo class.phpmailer.php localizado na pasta PHPMailer
require_once('PHPMailer/class.phpmailer.php');
require_once('database/config_base.php');
// Define busca a ser realizada no MySQL
$query= 'SELECT nome, sobrenome, email FROM usuarios;';
$resultado = mysql_query($query);
while ($linha = mysql_fetch_array($resultado, MYSQL_BOTH)) {
// Seleciona os campos, para cada linha
$nome=$linha['nome'];
$sobrenome=$linha['sobrenome'];
$email=$linha['email']; // Variáveis com assunto e mensagem
$subject = "\"Assunto da mensagem\"";
$mensagem = " Caro $nome $sobrenome, Aqui está a mensagem, Atenciosamente, Spammer "; // Inicia a classe PHPMailer
$mail=new PHPMailer(); // Define os dados do servidor e tipo de conexão
$mail->IsSMTP(); // Define que a mensagem será SMTP
$mail->SMTPAuth=true; // Usa autenticação SMTP? (obrigatório para alguns servidores, como o gmail)
$mail->Port=465;
$mail->SMTPSecure = "ssl";
$mail->Host='smtp_do_servidor';
$mail->Username='seu_e-mail'; // Usuário do servidor SMTP
$mail->Password='senha'; // Senha do servidor SMTP
// Define o remetente
$mail->SetFrom('seu_e-mail','seu_nome');
// Define os destinatário(s)
$mail->AddAddress($email,$nome.' '.$sobrenome);
//$mail->AddBCC('seu_e-mail', 'seu_nome'); // Cópia Oculta
// Define os dados técnicos da Mensagem
//$mail->IsHTML(true); // Define que o e-mail será enviado como HTML
//$mail->CharSet = 'UTF-8'; // Charset da mensagem (opcional)
$mail->Subject=$subject;
$mail->Body=$mensagem;
//$mail->AltBody = "Este é o corpo da mensagem de teste, em Texto Plano!";
//$mail->AddAttachment("/temp/documento.pdf", "novo_nome.pdf");  // Insere um anexo
// Cria e imprime variável de controle
$imprime=$nome." ".$sobrenome." ".$email."
";
// Exibe uma mensagem de resultado
echo $imprime;
if($mail->Send()){// Envia o e-mail
echo 'E-mail enviado com sucesso!';
}else{
echo 'Erro ao enviar e-mail: '.$mail->ErrorInfo;
}
sleep(10);
}
?>

 

Na duvida acredito que este video irá te ajudar...

 

https://www.youtube.com/watch?v=FRZ9gvvaYPo

 

 

 

 

Share this post


Link to post
Share on other sites

Caros amigos, saudações...

 

Depois de muita pesquisa e orientação no grupo, consegui realizar o envio de múltiplos e-mails.

 

O problema agora é que quando envio os e-mails, todos os envio aparece desta forma para os Clientes e/ou Fornecedores.

email_1@teste.com,email_2@teste.com,email_3@teste.com,email_4@teste.com,email_5@teste.com

 

Desta forma acima, quando o Cliente abre seu e-mail visualiza todos os outros demais que receberam também.

 

Como consigo fazer para que cada envio mostra somente o e-mail exclusivo de cada cliente ?

 

Abaixo posto meu código:

<?php



    //Função para Disparar Mensagem
    function disparaMensagem()
    {
      $idCts = $this->input->post('idCts');
      $idCta = str_pad($idCts, '5', '0', STR_PAD_LEFT);
      $idCli = $this->input->post('idCli');

      $idCtg = $this->input->post('idCtg');   //ID categoria 
      $razSoc = $this->input->post('razSoc'); //Razão Social
      $dtaEnv = $this->input->post('dtaEnv'); //Data envio
      $dtaEnv = $this->input->post('dtaEnv'); //Hora envio


      $cta = $idCli . '.' . $idCta;
      $data = date(('d/m/Y'), strtotime($dtaEnv));
      $hora = date(('H:i'), strtotime($dtaEnv));      

       //Chama a library - Email
       $this->load->library('email');
       // adquiri os E-mails para Enviar
       $recbmail = $this->envio_model->fetch_data($idCts,$idCtg);
       //Recebe os E-mails os Fornecedores
       $end_mail = null;        

       foreach ($recbmail->result_array() as $key => $value){ 
         //Separa os e-mails por vírgula
         $end_mail[] = implode(',', $value);
       }  

      $comunicStatus = 2;

      $retorno = $this->envio_model->editDispara($idCts, $comunictatus);
      if ($retorno) {

         //Laço para enviar os e-mails recebido do MySql
         //----> aqui faço um FOR para enviar os e-mails para cada Cliente
         for ($i=0; $i < $end_mail; $i++) {   
            error_reporting(E_ALL);
            ini_set("display_Errors", 1);
                          
            //Corpo do E-mail              
            $this->email->from('meu-email@hotmail.com');
            $this->email->to($end_mail);
            $this->email->subject('Comunicado');
            $this->email->message('<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
                    <html xmlns="http://www.w3.org/1999/xhtml">
                      <head>
                        <meta charset="utf-8">
                        <meta http-equiv="X-UA-Compatible" content="IE=edge">
                        <meta http-equiv="content-language" content="pt-br" /> 
                        <title>Teste de E-mail</title>
                      </head>
                      <body style="font-size:14px;">
                        <br/>
                          <b>Prezado Senhor Fornecedor</b><br/><br/>
                          <label style="font-size:14px; color:#0E0E8F;">
                            <b>Comunicado</b>
                          </label>
                          <br/><br/>
                          Empresa: <b>'.$razSoc.'</b><br/>
                          Comunica que estaremos fazendo saldão de estoque, aproveite.</b><br/> 
                          Data para Encerrar: <b>'.$data.'</b> às <b>'.$hora.'.</b>
                          <br/><br/>
                          <b>Por favor, não responder este e-mail</b>.
                      </body>
                    </html>');

            if($this->email->send()){
               $this->session->set_flashdata('success', '<h4>Comunicado - Disparado com Sucesso para o(s) Fornecedor(es).</h4>');
               redirect(base_url() . 'comunic/comunicado/editar/' . $this->input->post('idCts'));  
            } else {
              $this->session->set_flashdata('error', 'Ocorreu um erro ao tentar enviar Aviso de Comunicado!'); 
              redirect(base_url() . 'comunic/comunicado/editar/' . $this->input->post('idCts'));
            }//Fim do IF-send
         }//Fim do FOR
        

      } else {
        $this->session->set_flashdata('error', 'Ocorreu um erro ao tentar disparar a Comunicado. Por favor, informe ao Administrador do Sistema.');
        redirect(base_url() . 'comunic/comunicado/editar/' . $this->input->post('idCts'));
      }

    }


?>

 

Grato,

 

Cesar

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Kelven
      Existe alguma maneira de meu código não aparecer no código fonte que não seja por meio de Php? Tipo um código javascript que não apareça no código fonte? Quero fazer uma verificação if else se é um determinado valor de uma variável mas sem usar o php pois o blog só aceita javascript, html e css.
    • By Itamar Teixeira_94230
      Boa tarde, turma minha bronca é a seguinte, estou trabalhando usando url amigavel, preciso fazer o seguinte,
      quando o usuario acessa esse link 
      http://localhost/system/imprimir_seguro.php?cod=21 ele consegue gera normalmente e visualizar o pdf usando a classe dompdf
       
      mais queria usar da seguinte maneira como as demais url do sistema
       
      http://localhost/system/imprimir_seguro/21
      alguém pra me da esse help?
    • By blbvicente
      Olá amigos, gostaria de tirar uma dúvida para o andamento do meu projeto de conclusão de curso.
       
      Como posso fazer um código para alterar imagens no banco de dados via PHP e utilizando o MySQL com ambiente de admin?
       
      Como meu HTML e CSS estão prontos, (tanto a home quanto a página de login para o admin) a ultima parte que falta é conseguir fazer isso que lhes estou pedindo ajuda hahaha
       
      Desde já agradeço a ajuda! 
    • By sonix1309@gmail.com
      Boa tarde

      Minha primeira participação.

      Tenho dois Sistemas em servidores diferente:
      Mesma biblioteca mpdf60 mesma versão PHP 7.2 (ea-php72).

      Em um não ocorre erro nenhum, no outro ocorre o erro abaixo:
      Parse error: syntax error, unexpected 'var' (T_VAR), expecting end of file in /home/assetnet/public_html/site/sistema/mpdf60/mpdf.php on line 96
       
      ///////////////////////////////
      // EXTERNAL (PUBLIC) VARIABLES
      // Define these in config.php
      ///////////////////////////////
      (linha 96) var $useFixedNormalLineHeight;    // mPDF 6     <---- linha do ERRO
      (linha 97) var $useFixedTextBaseline;    // mPDF 6
      (linha 98) var $adjustFontDescLineheight;    // mPDF 6
      (linha 99) var $interpolateImages; // mPDF 6
      ...

       
    • By Rogerio Pancini
      Boa tarde pessoal.
       
      Sempre uso um script para exportar dados para xls com PHP.
      Me serviu muito, mas, neste caso, preciso apenas gerar o xls e anexar no e-mail.
      Passei boa parte de manhã tentando fazer que o script apenas gere a planilha, sem forçar o download, mas, se eu tiro o "Content-Disposition: attachment", dá erro na página.
       
      include("php/phpmailer/PHPMailerAutoload.php"); // Trazendo as informações da tabela: $header = ""; $dados = ""; $header .= utf8_decode('Serviço'. "\t"); $header .= utf8_decode('Projeto nº'. "\t"); $header .= utf8_decode('Cliente'. "\t"); $header .= utf8_decode('Processo'. "\t"); $header .= utf8_decode('Vencimento'. "\t"); // Select dos processos para fazer o lembrete $sql_2 = mysqli_query($config, "SELECT ps.data_vencimento_limite, ps.id_processo, IFNULL(NULL, ps.num_processo), ps.descricao, c.nome_razao FROM tb_processos_servicos ps LEFT JOIN tb_processos AS p ON (ps.id_processo = p.id_processo) LEFT JOIN tb_agenda AS c ON (p.cliente = c.id) WHERE ps.data_vencimento_limite <> '0000-00-00' AND ps.data_vencimento_limite <= '$data_atual_db' ORDER BY ps.data_vencimento_limite DESC") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_2) <= 0){ echo ""; }else{ while($r_sql_2 = mysqli_fetch_array($sql_2)){ $vencimento_limite = date("d/m/Y", strtotime($r_sql_2[0])); $id_processo = $r_sql_2[1]; $num_processo = $r_sql_2[2]; $descricao_sel = utf8_decode($r_sql_2[3]); $cliente_sel = utf8_decode($r_sql_2[4]); // Insere a linha $line = ''; $value = '"' ."$descricao_sel". '"' . "\t"; $value .= '"' ."$id_processo". '"' . "\t"; $value .= '"' ."$cliente_sel". '"' . "\t"; if(empty($num_processo)){ $value .= '""' . "\t"; }else{ $value .= '"' ."'$num_processo". '"' . "\t"; } $value .= '"' ."$vencimento_limite". '"' . "\t"; $line .= strtr($value,"","") ; // O trim retira os espaços encontrados no começo e no final de cada linha encontrada. $dados .= trim($line)."\n"; // Substituindo todas as quebras de linha ao final de cada registro, que por padrão seria \r por uma valor em branco, para que a formatao fique legível $dados = str_replace("\r","",$dados); // Caso não encontre nenhum registro, mostra esta mensagem. if ($dados== "") { $dados = "\n Nenhum registro encontrado!\n"; } } // O trim retira os espaços encontrados no começo e no final de cada linha encontrada. $dados .= trim($line)."\n"; // Substituindo todas as quebras de linha ao final de cada registro, que por padrão seria \r por uma valor em branco, para que a formatao fique legível $dados = str_replace("\r","",$dados); // Cabeçalhos e instruções para geração e download do arquivo: header("Content-type: application/x-msexcel"); // Este cabeçalho abaixo, indica que o arquivo deve ser gerado para download. // Se eu tirar ele salva o arquivo na pasta, mas dá erro na página header("Content-Disposition: attachment; filename=$nome_arquivo"); // No cache, ou seja, não guarda cache, pois é gerado dinamicamente header("Pragma: no-cache"); // Não expira header("Expires: 0"); // E aqui geramos o arquivo com os dados mencionados acima! print "$header\n$dados"; file_put_contents("anexos/".$nome_arquivo,$dados); //Aqui será enviado o e-mail. } mysqli_close($config); Não sei é possível apenas gerar o xls com esse script, mas ele é tão prático que vou fazer uma última tentativa.
      Neste caso ele salva na pasta "anexos", mas abre a caixa do navegador para fazer download.
       
      Desde já agradeço!
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.