Microsoft Graphで動作するSlim3 WebAppでguagueでleague/oauthクライアントを使用しています...指定されたリフレッシュトークンによって新しいトークンを正常に要求できません...Microsoft-Graphリフレッシュトークン要求が失敗しました... AADSTS70000
これはリーグ/ OAuthのクライアントのための私のジ - コンテナです:
$container['oauthprovider'] = function()
{
$provider = new \League\OAuth2\Client\Provider\GenericProvider(
[
'clientId' => getenv('ENV_CLIENT_ID'),
'clientSecret' => getenv('ENV_CLIENT_SECRET'),
'redirectUri' => getenv('ENV_REDIRECT_URL'),
'urlAuthorize' => getenv('ENV_AUTHORIZE_URL'),
'urlAccessToken' => getenv('ENV_URL_ACCESS_TOKEN'),
'urlResourceOwnerDetails' => '',
'scopes' => 'offline_access user.read people.read user.read.all openid mail.send'
]
);
return $provider;
};
作品罰金 - 私Slim3-Routeのリダイレクト後のI得たすべてのトークン、refresh_tokenなど
$provider = $this -> oauthprovider;
$CODE = filter_var($_GET['code'], FILTER_SANITIZE_FULL_SPECIAL_CHARS);
$accessToken = $provider -> getAccessToken('authorization_code',
['code' => $CODE]
);
...
$existingAccessToken = $accessToken -> getToken();
$refreshToken = $accessToken -> getRefreshToken();
$expiresIn = $accessToken -> getExpires();
$expired = ($accessToken -> hasExpired() ? true : false);
$client = $this -> guzzzle;
...
そして、私はこの時点で私のトークンをリフレッシュしよう - それが正常に動作している - 同じSlim3ルートに:
$newAccessToken = $provider -> getAccessToken('refresh_token', [
'refresh_token' => $accessToken -> getRefreshToken(),
'grant_type' => 'refresh_token'
]);
しかし、これは私の目標ではありません - 私は期限切れの寿命に達することによってトークンをリフレッシュする必要があります - 1時間 - 別Slim3-ルートで:
$accessToken = unserialize($session -> get('serialized_token'));
$refreshToken = unserialize($session -> get('serialized_refresh_token'));
$code = $session -> get('code');
$provider = $this -> oauthprovider;
$client = $this -> guzzzle;
...
$req = $client -> request('POST',
'https://login.windows.net/common/oauth2/token', [
'form_params' => [
'accept' => 'application/json',
'grant_type'=> 'refresh_token',
'client_id' => getenv('ENV_CLIENT_ID'),
'client_secret' => getenv('ENV_CLIENT_SECRET'),
'refresh_token' => (string) $refreshToken,
'redirect_uri' => getenv('ENV_REDIRECT_URL')
]
]);
応答:
Client error:
POST https://login.windows.net/common/oauth2/token
resulted in a400 Bad Request
response: {"error":"invalid_grant","error_description":"AADSTS70000: Transmission data parser failure: Refresh Token is malformed (truncated...)
リフレッシュトークンは、私は私の最初の要求で得たものと全く同じです。
oauth-client/guzzle/Microsoft Graphで何人かの経験がある方 - 私の/なんですか?
冒涜を避けてください。 –