使用PHP和MySQL发送多封电子邮件

时间:2016-12-21 10:31:57

标签: php mysql email

我在向MySQL数据库的地址子集发送电子邮件时遇到问题。

它应该发送3封电子邮件(email1,email2,email3),但它只是发送第一封(email1)。

<?php
    $query_iscritti = "SELECT * FROM richieste WHERE negozio LIKE 'NOMENEGOZIO'";
    $iscritti = mysql_query($query_iscritti, $conn) or die(mysql_error());
    $row_iscritti = mysql_fetch_assoc($iscritti);
    $totalRows_iscritti = mysql_num_rows($iscritti);
    $mittente = $_POST['mittente'];
    $destinatario = $row_iscritti['email'];
    $oggetto = $_POST['oggetto'];
    $messaggio = nl2br($_POST['messaggio']);
    $allegato = $_FILES['allegato']['tmp_name'];
    $allegato_type = $_FILES['allegato']['type'];
    $allegato_name = $_FILES['allegato']['name'];
    $headers = "From: " . $mittente;
    $msg = "";
    if (is_uploaded_file($allegato)) {
        $file = fopen($allegato,'rb');
        $data = fread($file, filesize($allegato));
        fclose($file);
        $data = chunk_split(base64_encode($data));
        $semi_rand = md5(time());
        $mime_boundary = "==Multipart_Boundary_x{$semi_rand}x";
        $headers .= "\nMIME-Version: 1.0\n";
        $headers .= "Content-Type: multipart/mixed;\n";
        $headers .= " boundary=\"{$mime_boundary}\"";
        $msg .= "This is a multi-part message in MIME format.\n\n";
        $msg .= "--{$mime_boundary}\n";
        $msg .= "Content-Type: text/html; charset=\"UTF-8\"\n";
        $msg .= "Content-Transfer-Encoding: 7bit\n\n";
        $msg .= $messaggio . "\n\n";
        $msg .= "--{$mime_boundary}\n";
        $msg .= "Content-Disposition: attachment; filename=\"{$allegato_name}\"\n";
        $msg .= "Content-Transfer-Encoding: base64\n\n";
        $msg .= $data . "\n\n";
        $msg .= "--{$mime_boundary}--\n";
    } else {
        $msg = $messaggio;
    }
    if (mail($destinatario, $oggetto, $msg, $headers)) {
    } else {
        print "Errore";
    }
    while ($row_iscritti = mysql_fetch_assoc($iscritti)); 
    echo ("EMAIL INVIATE CORRETTAMENTE");
?>

我认为问题出在while循环中。

3 个答案:

答案 0 :(得分:0)

我解决了! 我换了

while ($row_iscritti = mysql_fetch_assoc($iscritti));

while ($row_iscritti = mysql_fetch_assoc($iscritti))
mail($row_iscritti['email'], $oggetto, $msg, $headers);

答案 1 :(得分:-1)

var_dump $ row_iscritti并检查从数据库中获得的内容。如果你有一系列电子邮件,那么你需要循环邮件功能。如果您还有问题,请在此处注释转储结果

foreach ($destinatario as $email)
{
    mail($email....)
}

编辑: 你在6行($ destinario)收到电子邮件行,你在这里发送电子邮件:

if (mail($destinatario, $oggetto, $msg, $headers))

然后你开始循环:

while ($row_iscritti = mysql_fetch_assoc($iscritti)); 

做对了,检查一下你有什么:

while ($row_iscritti = mysql_fetch_assoc($iscritti))
{
    var_dump($row_inscritti);
}

答案 2 :(得分:-1)

while ($row_iscritti = mysql_fetch_assoc($iscritti))
{
var_dump($row_inscritti);
}

dump为我提供了包含MySQL数据库所有值的正确数组