使用messages.list获取消息的标识符,稍后将使用该标识符通过messages.get单独获取完全限定的消息。
由于某种原因,messages.list 会忽略请求中设置的字段,即谷歌发回仅包含默认字段的 json "messages(id,threadId),nextPageToken"。这就是为什么message.getRaw()返回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);
}
Run Code Online (Sandbox Code Playgroud)
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();
}
Run Code Online (Sandbox Code Playgroud)