得到#error = unsupported_response_type& error_description = AADSTS70005:带令牌请求

时间:2014-08-26 16:49:06

标签: azure oauth-2.0 azure-active-directory asp.net-identity-2

我正在尝试在IOS应用中实施OAuth2隐式授权流程。在这种情况下,它需要令牌请求而不是代码请求,因为您无法安全地在本机应用程序中共享客户端密钥。

所以像这样的请求会产生一个登录表单:

https://login.windows.net/<tenantid>/oauth2/authorize?api-version=1.0&client_id=<client id>&response_type=token&redirect_uri=shp-apps://localhost:44300/?ReturnUrl=%2F&resource=https://graph.windows.net

成功登录后,我收到此错误:

#error=unsupported_response_type&error_description=AADSTS70005: response_type 'token' 
  is not supported for the application
Trace+ID: 9008e580-2798-4b6c-a6bf-2bf614b61f64
Correlation+ID: ceb9bb4b-34a4-4441-801f-377f534543b1
Timestamp: 2014-08-26+16%3a24%3a24Z

这实际上是否正确,不支持令牌request_type?还是还有其他我需要做的事情?该应用程序设置为本机应用程序。我已经能够在同一个活动目录中的不同应用程序中执行“code”response_type。

2 个答案:

答案 0 :(得分:1)

Azure AD确实不支持隐式授权流程。对于您的iOS应用程序,请使用具有刷新令牌支持的授权代码授予流程。您无需自己编写OAuth流程 - 请改用我们的iOS / OSX SDK:https://github.com/AzureAD/azure-activedirectory-library-for-objc

菲利普,请继续关注隐含的赠款流程 - 这是我们的关注点。

希望这会有所帮助。

更新:Azure AD现在支持隐式授权OAuth流。见:https://github.com/AzureADSamples/SinglePageApp-AngularJS-DotNet

答案 1 :(得分:1)

查看本文如何在Azure门户的AAD App注册清单文件中设置“oauth2AllowImplicitFlow”。

https://msdn.microsoft.com/en-us/skype/websdk/docs/troubleshooting/auth/aadauth-enableimplicitoauth

<强>摘要

问题

在AAD中创建应用注册时,您需要手动编辑应用程序清单并将oauth2AllowImplicitFlow属性的值设置为true。否则AAD登录流程将无效 - 错误“AADSTS70005:response_type'token'不支持该应用程序......”

解决方案

请按照以下步骤解决此问题。

  1. 使用您租户中的管理员帐户登录portal.azure.com。
  2. 导航到左侧栏中的Azure Active Directory&gt;应用注册&gt;你的应用。
  3. 点击描述应用的窗格顶部的清单。
  4. 将属性oauth2AllowImplicitFlow的值更改为true。如果该属性不存在,请添加该属性并将其值设置为true
  5. 点击“保存”以保存修改后的清单。
  6. enter image description here