我在 Azure Active Directory 中注册了一个应用程序以findMeetingTimes
从 Microsoft Graph 调用。我能够成功授权、获取令牌并进行其他 Graph API 调用,但会收到一个401 - Unauthorized response
错误代码为“UnknownError”的端点https://graph.microsoft.com/v1.0/me/findMeetingTimes
。
我正在使用 Microsoft 工作帐户进行这些活动,并且可以使用该帐户登录并查看日历。我尝试了其他与日历相关的 API 调用,包括/me/calendar/getSchedule
并/me/events
收到了成功的响应。我主要使用 Postman 进行测试,但尝试使用 Graph Explorer 并得到相同的响应。
我还检查了我使用的令牌是否包含正确的范围Calendars.Read.Shared
和Calendars.ReadWrite.Shared
. 我最初尝试仅使用 的范围Calendars.Read.Shared
,但无济于事。
这是我在请求令牌时收到的响应:
{
"token_type": "Bearer",
"scope": "Calendars.Read.Shared Calendars.ReadWrite.Shared User.Read profile openid email",
"expires_in": 3600,
"ext_expires_in": 3600,
"access_token": "foo",
"refresh_token": "bar"
}
我提出的请求(主体为空,因为所有主体参数都是可选的):
POST /v1.0/me/findMeetingTimes HTTP/1.1
Host: graph.microsoft.com
Content-Type: application/json
Authorization: Bearer foo
我收到的 401 响应:
{
"error": {
"code": "UnknownError",
"message": "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">\r\n<html xmlns=\"http://www.w3.org/1999/xhtml\">\r\n<head>\r\n<meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"/>\r\n<title>401 - Unauthorized: Access is denied due to invalid credentials.</title>\r\n<style type=\"text/css\">\r\n<!--\r\nbody{margin:0;font-size:.7em;font-family:Verdana, Arial, Helvetica, sans-serif;background:#EEEEEE;}\r\nfieldset{padding:0 15px 10px 15px;} \r\nh1{font-size:2.4em;margin:0;color:#FFF;}\r\nh2{font-size:1.7em;margin:0;color:#CC0000;} \r\nh3{font-size:1.2em;margin:10px 0 0 0;color:#000000;} \r\n#header{width:96%;margin:0 0 0 0;padding:6px 2% 6px 2%;font-family:\"trebuchet MS\", Verdana, sans-serif;color:#FFF;\r\nbackground-color:#555555;}\r\n#content{margin:0 0 0 2%;position:relative;}\r\n.content-container{background:#FFF;width:96%;margin-top:8px;padding:10px;position:relative;}\r\n-->\r\n</style>\r\n</head>\r\n<body>\r\n<div id=\"header\"><h1>Server Error</h1></div>\r\n<div id=\"content\">\r\n <div class=\"content-container\"><fieldset>\r\n <h2>401 - Unauthorized: Access is denied due to invalid credentials.</h2>\r\n <h3>You do not have permission to view this directory or page using the credentials that you supplied.</h3>\r\n </fieldset></div>\r\n</div>\r\n</body>\r\n</html>\r\n",
"innerError": {
"request-id": "foo",
"date": "2019-06-21T13:52:00"
}
}
}
是否有任何其他配置可以更改以解决此问题?