Invalid_grant 页面重新加载后 Twinfield
Invalid_grant after page reload Twinfield
我目前正在尝试设置 Twinfield API。我相信我快到了,几乎...
我设法检索了一个 accessToken 和一个 refreshToken,但不知何故这只适用于第一页加载。重新加载页面后,我收到 'invalid_grant' 错误。我不确定哪里出了问题,因为它实际上是在第一页加载时工作。
这是我的代码:
$provider = new OAuthProvider([
'clientId' => 'clientId',
'clientSecret' => 'clientSecret',
'redirectUri' => 'http://127.0.0.1:8000'
]);
if (!isset($_GET['code'])) {
$options = [
'scope' => ['twf.user', 'twf.organisation', 'twf.organisationUser', 'offline_access', 'openid']
];
$authorizationUrl = $provider->getAuthorizationUrl($options);
$_SESSION['oauth2state'] = $provider->getState();
header('Location: ' . $authorizationUrl);
exit;
} elseif (empty($_GET['state']) || (isset($_SESSION['oauth2state']) && $_GET['state'] !== $_SESSION['oauth2state'])) {
if (isset($_SESSION['oauth2state'])) {
unset($_SESSION['oauth2state']);
}
exit('Invalid state');
} else {
try {
$accessToken = $provider->getAccessToken('authorization_code', [
'code' => $_GET['code']
]);
$refreshToken = $accessToken->getRefreshToken();
echo 'Access Token: ' . $accessToken->getToken() . "<br>";
echo 'Refresh Token: ' . $accessToken->getRefreshToken() . "<br>";
echo 'Expired in: ' . $accessToken->getExpires() . "<br>";
echo 'Already expired? ' . ($accessToken->hasExpired() ? 'expired' : 'not expired') . "<br>";
$office = \PhpTwinfield\Office::fromCode("someOfficeCode");
$connection = new \PhpTwinfield\Secure\OpenIdConnectAuthentication($provider, $refreshToken, $office);
// $offices = $officeApiConnector->listAllWithoutOfficeCode();
} catch (\League\OAuth2\Client\Provider\Exception\IdentityProviderException $e) {
// Failed to get the access token or user details.
exit($e->getMessage() . ' error');
}
我希望有人能告诉我更多关于我做错了什么。感谢您的帮助。
我使用会话计数器来确保每次刷新页面时都请求新的授权码。这样授权码总是匹配访问令牌和刷新令牌。
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use PhpTwinfield\ApiConnectors\CustomerApiConnector;
use PhpTwinfield\Secure\Provider\OAuthProvider;
use PhpTwinfield\Secure\OpenIdConnectAuthentication;
class TWFconnector
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle(Request $request, Closure $next)
{
session_start();
if (!isset($_SESSION['arr']['counter'])) {
$_SESSION['arr']['counter'] = 0;
} else {
$_SESSION['arr']['counter']++;
}
$twin_client_id = '';
$twin_client_secret = '';
$twin_client_uri = '';
$provider = new OAuthProvider([
'clientId' => $twin_client_id,
'clientSecret' => $twin_client_secret,
'redirectUri' => $twin_client_uri,
]);
if (!isset($_GET['code'])) {
$options = [
'scope' => ['twf.user', 'twf.organisation',
'twf.organisationUser', 'offline_access', 'openid']
];
$authorizationUrl = $provider->getAuthorizationUrl($options);
header('Location: ' . $authorizationUrl);
$_SESSION['arr']['counter'] = 0;
} elseif($_SESSION['arr']['counter'] > 1) {
header('Location: http://127.0.0.1:8000/');
} else {
$accessToken = $provider->getAccessToken('authorization_code', [
'code' => $_GET['code']
]);
$refreshToken = $accessToken->getRefreshToken();
$office = \PhpTwinfield\Office::fromCode("");
$connection = new OpenIdConnectAuthentication($provider,
$refreshToken, $office);
print_r($connection);
}
return $next($request);
}
}
我目前正在尝试设置 Twinfield API。我相信我快到了,几乎... 我设法检索了一个 accessToken 和一个 refreshToken,但不知何故这只适用于第一页加载。重新加载页面后,我收到 'invalid_grant' 错误。我不确定哪里出了问题,因为它实际上是在第一页加载时工作。
这是我的代码:
$provider = new OAuthProvider([
'clientId' => 'clientId',
'clientSecret' => 'clientSecret',
'redirectUri' => 'http://127.0.0.1:8000'
]);
if (!isset($_GET['code'])) {
$options = [
'scope' => ['twf.user', 'twf.organisation', 'twf.organisationUser', 'offline_access', 'openid']
];
$authorizationUrl = $provider->getAuthorizationUrl($options);
$_SESSION['oauth2state'] = $provider->getState();
header('Location: ' . $authorizationUrl);
exit;
} elseif (empty($_GET['state']) || (isset($_SESSION['oauth2state']) && $_GET['state'] !== $_SESSION['oauth2state'])) {
if (isset($_SESSION['oauth2state'])) {
unset($_SESSION['oauth2state']);
}
exit('Invalid state');
} else {
try {
$accessToken = $provider->getAccessToken('authorization_code', [
'code' => $_GET['code']
]);
$refreshToken = $accessToken->getRefreshToken();
echo 'Access Token: ' . $accessToken->getToken() . "<br>";
echo 'Refresh Token: ' . $accessToken->getRefreshToken() . "<br>";
echo 'Expired in: ' . $accessToken->getExpires() . "<br>";
echo 'Already expired? ' . ($accessToken->hasExpired() ? 'expired' : 'not expired') . "<br>";
$office = \PhpTwinfield\Office::fromCode("someOfficeCode");
$connection = new \PhpTwinfield\Secure\OpenIdConnectAuthentication($provider, $refreshToken, $office);
// $offices = $officeApiConnector->listAllWithoutOfficeCode();
} catch (\League\OAuth2\Client\Provider\Exception\IdentityProviderException $e) {
// Failed to get the access token or user details.
exit($e->getMessage() . ' error');
}
我希望有人能告诉我更多关于我做错了什么。感谢您的帮助。
我使用会话计数器来确保每次刷新页面时都请求新的授权码。这样授权码总是匹配访问令牌和刷新令牌。
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use PhpTwinfield\ApiConnectors\CustomerApiConnector;
use PhpTwinfield\Secure\Provider\OAuthProvider;
use PhpTwinfield\Secure\OpenIdConnectAuthentication;
class TWFconnector
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle(Request $request, Closure $next)
{
session_start();
if (!isset($_SESSION['arr']['counter'])) {
$_SESSION['arr']['counter'] = 0;
} else {
$_SESSION['arr']['counter']++;
}
$twin_client_id = '';
$twin_client_secret = '';
$twin_client_uri = '';
$provider = new OAuthProvider([
'clientId' => $twin_client_id,
'clientSecret' => $twin_client_secret,
'redirectUri' => $twin_client_uri,
]);
if (!isset($_GET['code'])) {
$options = [
'scope' => ['twf.user', 'twf.organisation',
'twf.organisationUser', 'offline_access', 'openid']
];
$authorizationUrl = $provider->getAuthorizationUrl($options);
header('Location: ' . $authorizationUrl);
$_SESSION['arr']['counter'] = 0;
} elseif($_SESSION['arr']['counter'] > 1) {
header('Location: http://127.0.0.1:8000/');
} else {
$accessToken = $provider->getAccessToken('authorization_code', [
'code' => $_GET['code']
]);
$refreshToken = $accessToken->getRefreshToken();
$office = \PhpTwinfield\Office::fromCode("");
$connection = new OpenIdConnectAuthentication($provider,
$refreshToken, $office);
print_r($connection);
}
return $next($request);
}
}