我在向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
循环中。
答案 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数据库所有值的正确数组