【问题标题】:PHP email to mysql database issue when not deleting emails from server不从服务器删除电子邮件时,PHP电子邮件到mysql数据库问题
【发布时间】:2015-05-22 15:11:55
【问题描述】:

我正在使用在这里找到的 php 类 etodb

http://www.phpclasses.org/package/3324-PHP-Retrieve-e-mail-messages-into-a-MySQL-database.html

它检查电子邮件帐户并将消息下载到 mysql 数据库中。它工作得很好,但是在每个循环结束时(循环收件箱中的每条消息)它会删除电子邮件。我知道如何阻止它删除电子邮件,但问题是由于某种原因,脚本不会将任何新电子邮件插入数据库,除非我允许它删除邮件或收件箱完全为空。

这里是上面引用的 php 类的结尾部分。本节仅循环遍历每条消息并将其插入数据库,如果设置,它将删除消息。总而言之,我的问题是让脚本正常工作,而无需删除消息或收件箱为空。

$total_messages = $this->num_message(); 

// IM ASSUMING THIS FOR LOOP IS NOT LOOPING MESSAGES CORRECTLY 
for ($i = 0; $i < $total_messages; $i++) {


#Get first message
$email = $this->email_get();

$ismsgdb = $this->db_add_message($email); // THIS INSERTS EACH MSG INTO DATABASE

#Get store dir
$dir = $this->dir_name();

$id_log = $this->add_db_log($email, 'Copy e-mail - start ');

foreach($this->partsarray as $part){
 if($part[text][type] == 'HTML'){
   #$message_HTML = $part[text][string];
   $this->db_update_message($part[text][string], $type= 'HTML');
 }elseif($part[text][type] == 'PLAIN'){
   $message_PLAIN = $part[text][string];
   $this->db_update_message($part[text][string], $type= 'PLAIN');
 }elseif($part[attachment]){
    #Save files(attachments) on local disc

   // $message_ATTACH[] = $part[attachment];
    foreach(array($part[attachment]) as $attach){
        $attach[filename] = $this->mimie_text_decode($attach[filename]);
        $attach[filename] = preg_replace('/[^a-z0-9_\-\.]/i', '_', $attach[filename]);
        $this->add_db_log($email, 'Start coping file:"'.strip_tags($attach[filename]).'"');

        $this->save_files($this->newid.$attach[filename], $attach[string]);
        $filename =  $dir.$this->newid.$attach[filename];
        $this->db_add_attach($attach[filename], $filename);
        $this->update_db_log('<b>'.$filename.'</b>Finish coping: "'.strip_tags($attach[filename]).'"', $this->logid);
    }
  //

 }elseif($part[image]){
    #Save files(attachments) on local disc

    $message_IMAGE[] = $part[image];

    foreach($message_IMAGE as $image){
        $image[filename] = $this->mimie_text_decode($image[filename]);
        $image[filename] = preg_replace('/[^a-z0-9_\-\.]/i', '_', $image[filename]);
        $this->add_db_log($email, 'Start coping file: "'.strip_tags($image[filename]).'"');


        $this->save_files($this->newid.$image[filename], $image[string]);
        $filename =  $dir.$this->newid.$image[filename];
        $this->db_add_attach($image[filename], $filename);
        $this->update_db_log('<b>'.$filename.'</b>Finish coping:"'.strip_tags($image[filename]).'"', $this->logid);
    }

 }

}
$this->spam_detect();
$this->email_setflag(); 
$this->email_delete(); // WHEN I REMOVE THIS THE SCRIPT WONT GRAB NEW EMAILS
$this->email_expunge(); // WHEN I REMOVE THIS THE SCRIPT WONT GRAB NEW EMAILS




$this->update_db_log('Finish coping', $id_log);


}

【问题讨论】:

    标签: php mysql imap pop3


    【解决方案1】:

    但你的问题是,在循环中,你一直在抓取第一封电子邮件。

    #Get first message
    $email = $this->email_get();
    

    该类有一个内部指针“$this->msgid”,您需要递增该指针以获取下一条消息。如果在调用函数之前将其设置为 $i + 1,您应该会收到下一条消息。

    #Get message determined b $i
    $this->msgeid = $i + 1;
    $email = $this->email_get();
    

    (注:已编辑,现已看到源代码)

    【讨论】:

    • 谢谢!我知道这很简单——你的解决方案解决了我的问题。
    猜你喜欢
    • 1970-01-01
    • 2014-03-28
    • 1970-01-01
    • 1970-01-01
    • 2014-09-03
    • 2015-02-11
    • 2017-08-29
    • 1970-01-01
    • 2017-10-09
    相关资源
    最近更新 更多