2

我有一个同步到 OneDrive 的应用程序。如果用户通过 GoDaddy 使用 Office365 并且我的 grant_type 为“refresh_token”,它不会返回 refresh_token,这反过来又不会让我刷新我当前拥有的令牌。我尝试添加access_type="offline",并且prompt="consent"在执行 POST 请求时无济于事。帮助?

这是我的代码:

credentials = OpenStruct.new
params = {
      client_id: client_credentials[:key],
      redirect_uri: redirect_url,
      client_secret: client_credentials[:secret],
      refresh_token: refresh_token,
      grant_type: 'refresh_token',
      resource: resource_id,
      access_type: 'offline',
      prompt: 'consent'
} 
RestClient.post(client.token_url, params) # doesn't return refresh_token
4

1 回答 1

0

根据请求,您似乎正在刷新令牌。基于 OAuth 2.0 代码授权流程,没有关于access_typeprompt的参数。您可以参考下面的支持参数:

在此处输入图像描述

这是供您参考的帖子:

POST /{tenant}/oauth2/token HTTP/1.1
Host: https://login.microsoftonline.com
Content-Type: application/x-www-form-urlencoded

client_id=6731de76-14a6-49ae-97bc-6eba6914391e
&refresh_token=OAAABAAAAiL9Kn2Z27UubvWFPbm0gLWQJVzCTE9UkP3pSx1aXxUjq...
&grant_type=refresh_token
&resource=https%3A%2F%2Fservice.contoso.com%2F
&client_secret=JqQX2PNo9bpM0uEihUPzyrh 
于 2016-09-12T02:46:46.560 回答