如何解决Python O365 Outlook 连接问题
我正在尝试用 Python 编写一个脚本,以从特定文件夹中获取新电子邮件并将附件保存到共享驱动器以上传到数据库。 Power Automate 可以工作,但保存附件的文件大小限制仅为 20 MB。我能够对令牌进行身份验证,但在尝试获取电子邮件时出现以下错误:
网址未经授权。 令牌不包含权限,或权限无法理解。
我已经包含了用于连接到 Microsoft Graph 的代码。
(凭据和tenant_id 在我的代码中是正确的,出于显而易见的原因将它们删除
from O365 import Account,MSOffice365Protocol,MSGraPHProtocol
credentials = ('xxxxxx','xxxxxx')
protocol = MSGraPHProtocol(default_resource='reporting.triometric@xxxx.com')
scopes_graph = protocol.get_scopes_for('message_all_shared')
scopes = ['https://graph.microsoft.com/.default']
account = Account(credentials,auth_flow_type='credentials',tenant_id="**",scopes=scopes,)
if account.authenticate():
print('Authenticated')
mailBox = account.mailBox(resource='reporting.triometric@xxxx.com')
inBox = mailBox.inBox_folder()
for message in inBox.get_messages():
print(message)
我已经通过 Azure 配置了权限以包含所有必要的“邮件”委托。
我的脚本的其余部分非常适合将文件上传到数据库。目前,附件必须每天多次手动保存在共享驱动器上,然后运行脚本进行上传。有我遗漏的步骤吗?任何见解将不胜感激!
解决方法
auth_flow_type='credentials'
表示您正在使用客户端凭据流。
在这种情况下,您应该添加应用程序权限而不是委派权限。
不要忘记点击“为{您的租户}授予管理员同意”。
更新:
如果您将 auth_flow_type 设置为“授权”,它将使用需要委托权限的身份验证代码流。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。