7

这是一个retrieve_email.js连接到我的 gmail 帐户并UNSEEN在某个日期后下载电子邮件的模块。该代码几乎是从[imap模块示例中复制的] 1

const Imap = require('imap');
const inspect = require('util').inspect;
const simpleParser = require('mailparser').simpleParser;

const imap = new Imap({
  user: 'mygmail@gmail.com',
  password: 'mypassword',
  host: 'imap.gmail.com',
  port: 993,
  tls: true
});

function openInbox(callback) {
    imap.openBox('INBOX', true, callback);
};

async function parse_email(body) {
  let parsed = simpleParser(body);
  ...............
};

module.exports = function() {
  imap.once('ready', function() {
    openInbox(function(err, box) {
      if (error) throw err;

      imap.search(['UNSEEN', ['SINCE', 'May 20, 2018']], function(err, results){
        if (err) throw err;
        var f = imap.fetch(results, {bodies: ''});
        f.on('message', function(msg, seqno) {
          console.log('Message #%d', seqno);
          var prefix = '(#' + seqno + ') ';
          msg.on('body', function(stream, info) {
            if (info.which === 'TEXT')
              console.log(prefix + 'Body [%s] found, %d total bytes', inspect(info.which), info.size);
              var buffer = '', count = 0;
              stream.on('data', function(chunk) {
                count += chunk.length;
                buffer += chunk.toString('utf8');
                parse_email(buffer);
                if (info.which === 'TEXT')
                  console.log(prefix + 'Body [%s] (%d/%d)', inspect(info.which), count, info.size);
              });
              stream.once('end', function() {
                if (info.which !== 'TEXT')
                  console.log(prefix + 'Parsed header: %s', inspect(Imap.parseHeader(buffer)));
                else
                  console.log(prefix + 'Body [%s] Finished', inspect(info.which));
              });
          });
          msg.once('attributes', function(attrs) {
            console.log(prefix + 'Attributes: %s', inspect(attrs, false, 8));
          });
          msg.once('end', function() {
            console.log(prefix + 'Finished');
          });
        });

        f.once('error', function(err) {
          console.log('Fetch error: ' + err);
        });

        f.once('end', function() {
          console.log('Done fetching all messages');
          imap.end();
        });

      });
    });
  });

  imap.once('error', function(err) {
    console.log(err);
  });

  imap.once('end', function() {
    console.log('Connection ended');
  });

  imap.connect();
};

当模块被调用时index.js,我可以在调试中看到代码是从上到下扫描的,扫描的最后一行代码是imap.connect()然后回到下一行index.js,与gmail帐户没有连接,也没有检索操作电子邮件。上面的代码有什么问题?

更新:socket.connect()调试后的状态: 在此处输入图像描述

4

2 回答 2

2

看看这个,这是来自 Google 的 Gmail API 参考。在该页面上有一个如何使用 Node.js 连接到它的示例。

https://developers.google.com/gmail/api/quickstart/nodejs

这是来自同一文档的示例,向您展示如何使用 q 参数搜索和检索消息列表:

https://developers.google.com/gmail/api/v1/reference/users/messages/list

PS 在我的评论中,我只是问您是否确定您完成了通过代码访问您的 Gmail 帐户所需的所有其他配置,这意味着创建应用程序、授权 OAuth 或在您的情况下授权不太安全的应用程序访问,只需查看您可能会发现缺少某些内容的链接。

你真的需要使用 IMAP 包吗???

于 2019-01-02T14:32:40.000 回答
1

发现的问题是 Avast mail shield 作为中间人拦截 IMAP 流量并导致 HTTPS 失败。此外,IDE 调试器会在某处停止以保持连接处于活动状态但尚未准备好。这是解决方案的详细信息

于 2019-01-09T02:13:37.787 回答