2

我想使用 php 代码限制每小时发送 90 封电子邮件

4

3 回答 3

3

您可以使用 PHP 以这种非常 hackish 的方式执行此操作:

创建一个名为 count_offset.txt 的空白文件,这将是一个跟踪分块集的 90 个用户的偏移量的文件。

创建另一个名为 count_emails.txt 的空白文件,这将是一个跟踪特定小时内发送的电子邮件数量的文件。

然后,运行电子邮件功能(通过 cron)的 PHP 脚本可以打开第一个文本文件以检查已发送的分块集,并发送给下一组用户。它可以检查第二个文件的 90 个电子邮件限制。

例如:

$userCount = getNumberOfUsers(); // Whatever query you may have that counts how many total users there are.

$numChunks = ceil($userCount/90); // How many different groups to send the email.

$chunkFile = fopen('chunk_offset.txt', 'r+'); // Loads the file as resource.
$currentChunk = fread($chunkFile, filesize('chunk_offset.txt')); // Load the contents of chunk_offset.txt into variable.
$currentChunk = ($currentCount == '' ? 0 : (int)$currentChunk); // Load 0 if contents of file blank.

$countFile = fopen('count_emails.txt', 'r+'); // Loads the file as a resource in variable $countFile.
$currentCount = fread($countFile, filesize('count_emails.txt')); // Load the content of the file into variable $currentCount.
$currentCount = ($currentCount == '' ? 0 : (int)$currentCount); // If the value of $currentCount is blank, then sets it to integer 0, otherwise sets the variable as the integer value of file contents.

if ($currentCount <= 90) // Test the variable to see if it's under the limit. If it's under, send the email.
{
    foreach ($whateverUserListYouHave as $integerKey => $emailAddress) // Iterating through whatever array of users you have.
    // Hopefully index number => email, but the index number is important.
    // Also, consistent ordering of the list of users is important.
    // Remember, you can always create your own counter.
    {
        // The magic:
        // You're testing for set of people who fall within the current chunk.
        if ($integerKey >= ($currentChunk * 90) && $integerKey < ($currentChunk * 90 + 90))
        {
            send_email($emailAddress); // Whatever arbitrary email function you have here.
        }
    }
}

$currentCount++; // Iterate up the count.
fwrite($countFile, $currentCount); // Write the new count into the file.

if ($currentChunk == $numChunks) // If the current chunk number hits the total number of groups of 90, then reset the file to blank...
{
    $currentChunk = '';
}
else if ($currentChunk < $numChunks) // ... Otherwise iterate up and let it hit the next chunk on the next hour.
{
    $currentChunk++; // Iterate up the chunk.
}
fwrite($chunkFile, $currentChunk);

之后,编写另一个 cron,每小时清除 count_emails.txt 文件(或将内容变为 0)。如果您愿意,这个其他 cron 可以运行另一个 PHP 脚本或者可以是 Bash 命令。

如果您想使用 Bash 命令执行此操作,这将是 cron:

0 * * * * cat /dev/null > count_emails.txt

上述行添加到 cron 时,使用 cat 清除 count_emails.txt 文件的内容。

干杯,祝你好运!

于 2012-07-07T06:46:56.377 回答
1

PHP 本身不足以胜任这项工作。您可以编写 PHP 来执行实际发送(以及 90 的限制),但对于调度,您需要在您的服务器上使用cron或类似机制,它被配置为定期调用您的 PHP 文件。

于 2012-07-07T05:50:03.543 回答
0

在https://a1websitepro.com/sending-emails-every-hour-server-limit-php/上有一个关于这个主题的深入教程 这是您将使用 cron 运行的代码。

    <?php
include('config.php');
$result = $con->query("SELECT * FROM newsletter     ORDER BY id DESC LIMIT 1") ;
while ($row = $result->fetch_assoc()) {
 $newid=$row['id'];
$thtetitle=$row['title'];
$thecontent=$row['content'];
echo '<hr/>';
}
$resultt = $con->query("SELECT * FROM users WHERE      emailed <> $newid ORDER BY id ASC LIMIT 50") ;
while ($rowt = $resultt->fetch_assoc()) {
$userid=$rowt['id'];
$email= $rowt['email'];
echo '<hr/>';
$to = $email;
$subject = $thetitle;
$message = $thecontent;
$headers = 'From: you@yourwebsite.com' . "\r\n" .
'Reply-To: noreply@yourwebsite.com' . "\r\n" .
'X-Mailer: PHP/' . phpversion();
mail($to, $subject, $message, $headers);
mysqli_query($con,"UPDATE users SET     emailed='$newid'
WHERE id='$userid' ");
}
$con->close();
?>

这是上传教程中的所有脚本后,您将在 cPanel 中插入的 cron 代码。/usr/bin/php -q /home/cpanelusername/public_html/sendnewsletter.php

于 2015-12-17T17:47:30.110 回答