我可以使用 Microsoft Graph API
获取邮箱和附件详细信息样品请求
GET https://outlook.office.com/api/v2.0/me/messages/AAMkAGI2THVSAAA=/attachments?$select=Name
回复示例
状态代码:200
{
"@odata.context": "https://outlook.office.com/api/v2.0/$metadata#Me/Messages('AAMkAGI2THVSAAA%3D')/Attachments(Name)",
"value": [
{
"@odata.type": "#Microsoft.OutlookServices.FileAttachment",
"@odata.id": "https://outlook.office.com/api/v2.0/Users('ddfcd489-628b-40d7-b48b-57002df800e5@1717622f-1d94-4d0c-9d74-709fad664b77')/Messages('AAMkAGI2THVSAAA=')/Attachments('AAMkAGI2j4kShdM=')",
"Id": "AAMkAGI2j4kShdM=",
"Name": "minutes.docx"
}
]
}
我需要使用 Microsoft Graph API 下载附件的服务。
使用 C#.NET 时:
await graphClient.Users["[email protected]"].MailFolders.Inbox.Messages.Request()
.Expand("attachments").GetAsync();
或
await graphClient.Me.MailFolders.Inbox.Messages.Request()
.Expand("attachments").GetAsync();
问候
PS:这现在已经过时了!使用 GetAsync(config => {}) 时,过滤器表达式现在必须由 config.QueryParameters.Expand 提供!
是的,您可以从 Microsoft Graph API 本地下载该文件。您需要将字节流转换为 Base64 解码数据。这是代码
$curl = curl_init();
curl_setopt_array($curl, array(
CURLOPT_URL => "https://graph.microsoft.com/v1.0/me/messages/your_message_id/attachments",
CURLOPT_RETURNTRANSFER => true,
CURLOPT_CUSTOMREQUEST => "GET",
CURLOPT_HTTPHEADER => array(
"Prefer: IdType=\"ImmutableId\"",
"Authorization: Bearer your_access_token"
),
));
$response = json_decode(curl_exec($curl),true);
curl_close($curl);
$fileName = $response['value'][0]['name'];
$contents = base64_decode($response['value'][0]['contentBytes']);
header("Content-type: ".$response['value'][0]['contentType']);
header("Content-Disposition: attachment; filename=" . $fileName);
print $contents;
die;
供其他正在使用Python的用户参考,希望能帮助您节省一些时间
import io
import response
url = f"https://graph.microsoft.com/v1.0/me/messages/{email_id}/attachments/{attachment_id}/$value"
payload={}
headers = {
'Content-Type': 'application/json',
'SdkVersion': 'postman-graph/v1.0',
'Authorization': f'Bearer {access_token}'
}
response = requests.request("GET", url, headers=headers, data=payload, allow_redirects=False)
toread = io.BytesIO()
toread.write(response.content)
toread.seek(0)
df = pd.read_excel(toread)
print(df)
根据您的描述,我假设您想使用 MS Graph API 下载附件。
根据我的测试,我们可以使用以下步骤来下载附件。
第1步,我们应该使用以下API获取附件ID:
GET /me/messages/{id}/attachments
GET /users/{id | userPrincipalName}/messages/{id}/attachments
Step2,我们可以使用以下代码下载附件。
Chilkat.StringBuilder sbSavePath = new Chilkat.StringBuilder();
Debug.WriteLine("name: " + json.StringOf("value[i].name"));
Debug.WriteLine("contentType: " + json.StringOf("value[i].contentType"));
int sizeInBytes = json.IntOf("value[i].size");
Debug.WriteLine("size: " + Convert.ToString(sizeInBytes));
// Extract the data and save to a file.
sbSavePath.SetString("qa_output/");
sbSavePath.Append(json.StringOf("value[i].name"));
attachData.Clear();
attachData.AppendEncoded(json.StringOf("value[i].contentBytes"),"base64");
attachData.WriteFile(sbSavePath.GetAsString());
// Get the last-modified date/time and set the output file's last-mod date/time..
lastMod.SetFromTimestamp(json.StringOf("value[i].lastModifiedDateTime"));
fac.SetLastModified(sbSavePath.GetAsString(),lastMod);
更详细的简单代码,可以参考这个文档。
如果我们使用的是测试版的 API,并且附件是在线文件,我们还可以使用
sourceUrl
属性来下载附件。
这里是关于如何下载附件的已解决问题。可能对你有帮助。