【问题标题】:php does not send mail to recipientsphp 不向收件人发送邮件
【发布时间】:2014-08-28 10:26:44
【问题描述】:

我有一个 php 脚本,它应该向多个收件人发送邮件。我想将所有收件人都写到密件抄送。电子邮件地址是从 mysql 数据库中检索的。不幸的是,它不会发送任何邮件。

这是脚本:

    <?php
include("/path/to/config.php"); 
$db = @new mysqli($mysql_host, $mysql_user, $mysql_pass, $mysql_db);
if (mysqli_connect_errno()) {
    die ('Konnte keine Verbindung zur Datenbank aufbauen: '.mysqli_connect_error().'('.mysqli_connect_errno().')');
}

$sql = "select email from newsletter";
$recipients = array();
$result = $db->query($sql);     

if (!$result) {
  printf("Query failed: %s\n", $mysqli->error);
  exit;
}      
while($row = $result->fetch_row()) {
   $recipients[]=$row;
}

print_r($recipients);

$result->close();
$db->close();


$to = 'myemail';
$subject = $_POST["subject"];
$body = $_POST["message"];
$headers  = 'MIME-Version: 1.0' . "\r\n";
$headers .= 'Content-type: text/html; charset=iso-8859-1' . "\r\n";
$headers .= 'Reply-To: support@mymail.de' . "\r\n";
$headers .= 'BCC: ' . implode(', ', $recipients) . "\r\n";

mail($to, $subject, $body, $headers);

?>

print_r 返回一个有效的响应:

Array ( [0] => Array ( [0] => first@mail.com ) [1] => Array ( [0] => second@mail.com ) )

【问题讨论】:

  • mail 的调用返回什么?
  • 基本调试会使问题变得明显。 echo $headers 显示什么?
  • 小心密件抄送可能会有限制,具体取决于邮件服务器

标签: php mysql arrays email implode


【解决方案1】:

你正在创建一个数组数组:

while($row = $result->fetch_row()) {
      ^^^^---array
   $recipients[]=$row;
                 ^^^^---add array to another array
}

你可能想要类似的东西

while($row = ...) {
  $recipients[] = $row[0];
}

所以您只添加了电子邮件地址。

由于您正在分解您的数组数组,并将生成的字符串填充到另一个字符串中,因此您将真正得到BCC: Array, Array, Array, ....

【讨论】:

  • 谢谢你这样做。我只能在大约 5 分钟内接受。谢谢;)
猜你喜欢
  • 2021-07-19
  • 1970-01-01
  • 1970-01-01
  • 2020-09-15
  • 2012-09-24
  • 2014-05-13
  • 2014-02-06
  • 1970-01-01
相关资源
最近更新 更多