Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/242.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Phpmailer和异步发送电子邮件_Php_Asynchronous - Fatal编程技术网

Phpmailer和异步发送电子邮件

Phpmailer和异步发送电子邮件,php,asynchronous,Php,Asynchronous,在这里提问之前,我读了一些其他问题,因为其他答案对我的问题没有反应 我有一个定制的php cms。例如,如果插入新付款,脚本将向所有管理员用户发送通知: function insert_payment() { // CODE TO INSERT PAYMENT INSIDE MYSQL DB $sql_payment = "INSERT INTO payments ($amount, ...) VALUES (?, ...);" ... // NOTIFY ALL ADMINS foreach

在这里提问之前,我读了一些其他问题,因为其他答案对我的问题没有反应

我有一个定制的php cms。例如,如果插入新付款,脚本将向所有管理员用户发送通知:

function insert_payment() {
// CODE TO INSERT PAYMENT INSIDE MYSQL DB
$sql_payment = "INSERT INTO payments ($amount, ...) VALUES (?, ...);"
...
// NOTIFY ALL ADMINS
foreach ( $array_emails as $email ) {
   send_email_to_admin($email, $subject, $body);
  }


  // redirect to dashboard
  header("Location: " . $homepage);
}

这是
send\u email\u to\u admin()
函数的一个示例:

function send_email_to_admin($email, $subject, $body) {
       // return example:
       // $result = array(
       //      "Error" = true or false
       //      "DateTimeOfSent" = datetime
       //      "Email" = string
       //)
       // SAVE RESULTS IN MYSQL DB ( I need to register results to be sure email are sent without errors...table can be then seen to a specific pages under admin panel of cms)

       $mail = new PHPMailer;
       ...
       ...
       if(!$mail->send()) {
  $result = array("Error" => true, "DateTimeOfSent" => date("Y-m-d"), "Email" => $mail);
} else {
  $result = array("Error" => false, "DateTimeOfSent" => date("Y-m-d"), "Email" => $mail);
}

       $sql_result = "INSERT INTO SentResult ("Error", "DateTimeSent", "Email", ...) VALUES ( $result['Error'], $result['DateTimeOfSent'], $result['Email'] )"
       ...
       //end function
}
现在,如果我有1个或2个管理员就可以了……但是如果我有很多管理员,那么等待每次发送结果的时间间隔就不好了

如果可能的话,我想把foreach循环传递给一个子进程,这个子进程可以异步处理整个发送和保存结果的循环

因此,可以立即执行
标题(“位置:”.$homepage)

其他一些信息:

  • 我正在使用托管服务器,因此无法安装软件包和库

  • 我只能使用默认PHP配置提供的函数

  • 我不能使用cronjob队列方法,因为我的主机没有提供免费服务

  • 我想要一个在IIS windows服务器和基于Linux的服务器上工作的解决方案

  • 我想要一个基于我的代码的小脚本示例,因为我从未在php中使用过异步方法,对此我一无所知:(


    对不起,我讲的是英语

    您可以实现一个队列并使用curl调用(异步)处理该队列

    不要直接从函数
    send_email\u to_admin()
    发送电子邮件,而是在专用SQL表
    EmailQueue
    中插入一个新的数据集。接下来,编写一个递归函数,处理此队列(所有等待发送的电子邮件),直到表
    EmailQueue
    为空

    插入付款:

    ...
    // NOTIFY ALL ADMINS
    foreach ( $array_emails as $email ) {
       queue_email($email, $subject, $body);
    }
    
    curl_process_email_queue();
    ...
    
    进行CURL调用,以从父脚本()分离:

    排队电子邮件:

    function queue_email($email, $subject, $body) {
        $sql = "INSERT INTO emailQueue ("email", "subject", "body") VALUES ($email, $subject, $body)";
        ...
    };
    
    将PHP
    send_queued_emails分开。通过URL通过cURL调用PHP
    脚本,该脚本实际发送排队的电子邮件(递归,直到队列为空):


    发送给每个管理员的电子邮件是否相同?如果是,只需发送一封电子邮件,其中包含“收件人”中所有不同的电子邮件地址fieldno…$body对每个管理员都是个性化的。但这只是一个例子…我的目标是在所有情况下实现一个异步交付方法。我不寻找同时使用多个地址的phpmailer的解决方法…可能会有帮助,有或没有cURL部分。哇,这也是一个很好的答案。我会在我的本地主机上尝试。我不知道我现在不知道我的托管服务器中是否有cURL可用,所以…告诉我插入一个检查是否是一个好主意,比如if(function_exists('cURL_version'))。如果是true,请发布你的方法。如果是false…继续使用我的原始脚本…防止任何兼容性好吗?@itajackass我想你可以通过查看phpinfo()来判断cURL是否可用对于serverKlee,您能澄清其中的异步部分在哪里吗?PHP中的cURL不是异步的default@ADyson是的,我可以直观地完成……但是如果我使用变量检查……我可以为这两种情况编写一个“通用”脚本……不是吗?@ADyson,因为cURL调用在1秒后超时,然后它会与调用脚本分离(如果之前没有完成cURL调用)。有关更多详细信息和其他选项,请参阅上述文章:
    
    function queue_email($email, $subject, $body) {
        $sql = "INSERT INTO emailQueue ("email", "subject", "body") VALUES ($email, $subject, $body)";
        ...
    };
    
    <?php
    
    // close connection early, but keep executing script
    // https://stackoverflow.com/a/141026/5157195
    ob_end_clean();
    header("Connection: close");
    ignore_user_abort(true);
    ob_start();
    echo('Some status message');
    $size = ob_get_length();
    header("Content-Length: $size");
    header("Content-Encoding: none");
    ob_end_flush();
    flush();
    // connection is closed at this point
    
    // start actual processing here
    send_queued_emails();
    
    function send_queued_emails() {
        // avoid concurrent access
        $sql = 'START TRANSACTION'; 
        mysqli_query($sql);
    
        // read one item from the queue
        $sql = 'SELECT "id", email", "subject", "body" FROM emailQueue LIMIT 1';
        $result = mysqli_query($sql);
    
        // if no more datasets are found, exit the function
        if (!$result || (mysqli_num_rows($result) == 0))
          return; 
    
        // mail the queried data
        $mail = new PHPMailer;
        ...
    
        // optionally write the result back to database
        $sql_result = 'INSERT INTO SentResult ... ';
        mysqli_query($sql);
    
        // delete the email from the queue
        $sql = 'DELETE FROM emailQueue WHERE "id"=...';
        mysqli_query($sql);
    
        // commit transaction
        $sql = 'COMMIT'; 
        mysqli_query($sql);
    
        // recursively call the function
        send_queued_emails();
    };