使用zend_mail对电子邮件进行排序的最有效方法是什么?

时间:2010-10-07 17:05:47

标签: php mysql zend-framework zend-mail

我正在整理查找特定字符串实例的电子邮件,这花费的时间太长了。我希望每封电子邮件的时间缩短到半秒,目前每封电子邮件大约需要2-2.5秒。

我担心我正在做一些非常愚蠢的事情,这会减慢这种速度 - 可能是使用mysql或zend_email。这段代码的作用是检查用户的收件箱中是否有特定的短语“chocolate”,然后将值返回给jquery ajax函数。它循环十次(在这个版本中,它检查10封电子邮件)。如果你看到任何有助于减少加载时间的东西,我们将不胜感激。最初,我认为不包括库会有所帮助,但没有电子邮件打开功能的库是闪电般快速。

我确信我正在做一些愚蠢和业余的事情(也许是一些事情)。如果可能,请指出它们。

这是代码......

<?php
        $storage = new Zend_Mail_Storage_Imap($imap);


    $x=0;
    while($x<10)
    {
            $flags = $storage->getMessage($i)->getFlags();      

            if(!empty($flags['\Seen']))
            {
                $read=1;
            }

            else 
            {
                $read=0;
            }


        if (strpos($storage->getMessage($i),'chocolate') !== FALSE ) 
        {
            $fromaddress = str_replace("'","",$storage->getMessage($i)->from);
            $fromaddress = str_replace('"','',$fromaddress);

            $sql = "SELECT `senderemail`,`subscribed` FROM email_spam WHERE `useremail` = '$_SESSION[email_address]' AND `senderemail` = '$fromaddress'";   $result = mysql_query($sql) or die (mysql_error());

            $num = mysql_num_rows($result);

            if($num == 0)
            {
                $emailmessage = mysql_escape_string($storage->getMessage($i)->getContent());



                $sql_insert = "INSERT into `email_spam` (`message`,`useremail`,`senderemail`,`datetime`,`subscribed`) VALUES ('$emailmessage','$_SESSION[email_address]','$fromaddress',now(),1)";//        echo $sql_insert;

                mysql_query($sql_insert,$link) or die("Insertion Failed:" . mysql_error());

                $sql = "SELECT `emailid`,`datetime` FROM email_spam WHERE `useremail` = '$_SESSION[email_address]' ORDER BY `datetime` desc";       $getid = mysql_query($sql) or die (mysql_error());

                $num = mysql_num_rows($getid);

                echo '<tr><td>'. $fromaddress . '</td>';

                echo '<td class="unsubscribe_td" align="center"><input type="submit" value="Unsubscribe Me" class="unsubscribe_button" id="'. mysql_result($getid,0,'emailid') .'"/></td></tr>';

            }
        }



        if ($read==0)
        {

            $storage->setFlags($i, array(Zend_Mail_Storage::FLAG_RECENT)); //marks as new
        }   


        $i--;
        $x++;
    }

    ?>

1 个答案:

答案 0 :(得分:0)

分析这一点毫无意义 - 这只是错误的方法。您正在为每条消息执行单独的IMAP请求和数据传输,这将永远不会很快。最有效的方法是不要在这里完成 - 让IMAP服务器为您进行搜索。它可能不像你正在做的那么灵活,但它每秒搜索成千上万条消息都没有问题,它肯定可以在消息体中进行简单的字符串匹配。 IMAP扩展中的PHP has support for searching inboxes。我不知道该函数是否通过任何Zend组件公开,但如果不是这样,那就不重要了。

这正是iPhone收件箱搜索使用的机制;它对已有的消息进行本地搜索,但随后提供了继续在服务器上进行搜索的选项,该服务器可以提供已经获得数据并具有更多马力的服务。