3

我正在尝试从 Gmail 下载附件,使用我在网上找到的代码片段的组合,以及我自己的一些编辑。但是,以下代码:

import email, getpass, imaplib, os, random, time
import oauth2 as oauth
import oauth2.clients.imap as imaplib

MY_EMAIL = 'example@gmail.com'
MY_TOKEN = "token"
MY_SECRET = "secret"

consumer = oauth.Consumer('anonymous', 'anonymous')
token = oauth.Token(MY_TOKEN, MY_SECRET)

url = "https://mail.google.com/mail/b/"+MY_EMAIL+"/imap/"
m = imaplib.IMAP4_SSL('imap.gmail.com')

m.authenticate(url, consumer, token)

m.select('INBOX')

items = m.select("UNSEEN"); 
items = items[0].split() 

for emailid in items:
    data = m.fetch(emailid, "(RFC822)")

返回此错误:

imaplib.error:命令 FETCH 在状态 AUTH 中非法

为什么在我获得授权时 Fetch 是非法的?

4

2 回答 2

3

您在调用 select 时缺少错误检查。通常,这是我将如何构建与邮箱的连接的第一部分:

# self.conn is an instance of IMAP4 connected to my server.
status, msgs = self.conn.select('INBOX')

if status != 'OK':
  return # could be break, or continue, depending on surrounding code.

msgs = int(msgs[0])

本质上,您遇到的问题是您选择了一个不存在的邮箱,您的状态消息可能不是应有的“OK”,并且您正在迭代的值无效。请记住,选择需要一个邮箱名称。它不会根据标志进行搜索(这可能是您尝试使用“UNSEEN”的方式)。当您选择一个不存在的邮箱时,您实际上会得到以下响应:

('NO', ['The requested item could not be found.'])

在这种情况下,for email id in items操作不正常。不幸的是,这不是你所追求的。您在有效邮箱上会得到如下信息:

('OK', ['337'])

希望有帮助。

要解决评论中的问题,如果您想实际检索邮箱中看不见的消息,您可以使用:

status, msgs = self.conn.select('INBOX')
# returns ('OK', ['336'])

status, ids = self.conn.search(None, 'UNSEEN')
# returns ('OK', ['324 325 326 336'])

if status == 'OK':
  ids = map(int, ids[0].split())

响应将类似于来自 select 的响应,但您将获得一个 id 列表,而不是消息数量的单个整数。

于 2011-03-04T22:48:01.307 回答
3

为什么在我获得授权时 Fetch 是非法的?

IMAP 有一个状态概念。

如果您选择了一个文件夹,您只能获取消息。

这是一张很好的图片,它显示了这一点:

IMAP 状态

图片来源:http ://www.tcpipguide.com/free/t_IMAP4GeneralOperationClientServerCommunicationandS-2.htm

于 2015-09-24T10:00:01.837 回答