如何使用 Gmail 获取电子邮件正文内容 API

How to get email body content using Gmail API

我正在使用 Gmail API 在我的简单 Java 应用程序中获取电子邮件数据,我使用 quickstart 获得了我想要的一切,但我无法获得完整的电子邮件内容。我使用了 message.getRaw() 但它 returns 为空。 所以,任何人都可以帮助我如何访问电子邮件内容。

使用messages.list获取消息的标识符,后面会用到fully-qualified通过 messages.get 分别发送消息。

出于某种原因 messages.list 忽略 请求中设置的字段,即 google 发回仅包含默认字段的 json "messages(id,threadId),nextPageToken"。这就是为什么 message.getRaw() returns null.

api-explorer - gmail.users.messages.list

/**
 * Returns empty messages sent between after and before 
 * that contain only identifiers.
 * @param after
 * @param before
 * @param fields fields to be included in response 
 *               (IGNORED see api-explorer)  
 * @return 
 */
public List<Message> getEmptyMessages(Date after, Date before, String fields) {    
    Gmail.Users.Messages.List request = gmailService.users().messages().list("me")
             // or setQ("is:sent after:yyyy/MM/dd before:yyyy/MM/dd")
            .setLabelIds(Arrays.asList("SENT"))
            .setQ("after:" + gmailFormat(after) +" "+ 
                  "before:"+ gmailFormat(before))
            .setMaxResults(MAX_RESULTS)
            .setFields(fields);

    List<Message> list = new LinkedList<>();
    ListMessagesResponse response = null;

    do {
       response = request.execute();
       list.addAll(response.getMessages());
       request.setPageToken(response.getNextPageToken());

    } while (request.getPageToken() != null && request.getPageToken().length() > 0);

    return list;
}

public String gmailFormat(Date d) {
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd");
    return sdf.format(d);
}

api-explorer - gmail.users.messages.get

/**
 * Returns "fully-qualified" message.
 * @param id     identifier of the message to be obtained.
 * @param fields fields to be included in response e.g. "raw,snippet"
 *               (use api-explorer to build this string)
 * @return 
 */
public Message getFullyQualifiedMessage(String id, String fields) {
    return gmailService.users().messages().get("me", id)
            .setFormat("FULL")
            .setFields(fields)
            .execute();
}