Php Quick Books创建客户OAuth 2.0令牌错误
我得到这个错误 PHP致命错误:未捕获QuickBooksOnline\API\Exception\ServiceException:Http状态代码[400]:使用刷新令牌刷新OAuth 2访问令牌失败。正文:[{“error”:“invalid_grant”}]。\n\n在第271行的/var/www/project1/vendor/quickbooks/v3 php sdk/src/Core/OAuth/OAuth2/OAuth2LoginHelper.php中抛出,请参考: 我做错了什么。谢谢。Php Quick Books创建客户OAuth 2.0令牌错误,php,api,quickbooks,Php,Api,Quickbooks,我得到这个错误 PHP致命错误:未捕获QuickBooksOnline\API\Exception\ServiceException:Http状态代码[400]:使用刷新令牌刷新OAuth 2访问令牌失败。正文:[{“error”:“invalid_grant”}]。\n\n在第271行的/var/www/project1/vendor/quickbooks/v3 php sdk/src/Core/OAuth/OAuth2/OAuth2LoginHelper.php中抛出,请参考: 我做错了什么
- 首先,您必须手动生成刷新令牌和accesstoken 第一次李>
- 因为第一次获取刷新令牌和访问令牌 需要验证代码李>
- 因此,您必须在生成刷新令牌之后生成authcode 和accesstoken
- 在那之后你可以试试,它很好用
注意:如果您获得了无效的授权,那么您必须在生成accesstoken和referesh token之后生成authcode是的,我修复了它。我使用刷新访问令牌生成访问密钥和刷新密钥。谢谢。@DragiPostolovski,你能发布你的解决方案吗?遇到类似错误,你能发布你如何使用刷新访问令牌生成新的访问/刷新密钥吗?@AJ47你成功了吗。。我有同样的issue@the_big_blackbox不完全是这样,我发布了一个类似的问题,但没有得到我想要的答案,如何在没有Composer的情况下安装PHPSDK?
use QuickBooksOnline\API\DataService\DataService;
use QuickBooksOnline\API\Core\Http\Serialization\XmlObjectSerializer;
use QuickBooksOnline\API\Facades\Customer;
use QuickBooksOnline\API\Core\OAuth\OAuth2\OAuth2LoginHelper;
$oauth2LoginHelper = new OAuth2LoginHelper("clientId","clientSecret");
$accessTokenObj = $oauth2LoginHelper->refreshAccessTokenWithRefreshToken("Q02i05iXG98OaKON8coU5fKmUCuzEkESkpkbXUcViPVnXaJ1eK");
$accessTokenValue = $accessTokenObj->getAccessToken();
$refreshTokenValue = $accessTokenObj->getRefreshToken();
// Prep Data Services
$dataService = DataService::Configure(array(
'auth_mode' => 'oauth2',
'ClientID' => "ClientID",
'ClientSecret' => "ClientSecret",
'accessTokenKey' => $accessTokenValue,
'refreshTokenKey' => $refreshTokenValue,
'QBORealmID' => "3644364364363463634",
'baseUrl' => "sandbox-quickbooks.api.intuit.com"
));
$dataService->setLogLocation("/Users/hlu2/Desktop/newFolderForLog");
$dataService->throwExceptionOnError(true);
//Add a new Vendor
$theResourceObj = Customer::create([
"BillAddr" => [
"Line1" => $clientInformation['clientHomeAddress'],
"City" => "t43",
"Country" => "43t3",
"CountrySubDivisionCode" => "34tt334",
"PostalCode" => ""
],
"Notes" => "3t34t",
"Title" => "34t434t",
"GivenName" => $clientName[0],
"MiddleName" => "rehhhreherher",
"FamilyName" => $clientName[1],
"Suffix" => "Jr",
"FullyQualifiedName" => $clientInformation['clientName'],
"CompanyName" => "43t334t",
"DisplayName" => $clientInformation['clientName'],
"PrimaryPhone" => [
"FreeFormNumber" => $clientInformation['clientPhoneNumber']
],
"PrimaryEmailAddr" => [
"Address" => $clientInformation['clientEmail']
]
]);
$resultingObj = $dataService->Add($theResourceObj);
$error = $dataService->getLastError();
if ($error) {
echo "The Status code is: " . $error->getHttpStatusCode() . "\n";
echo "The Helper message is: " . $error->getOAuthHelperError() . "\n";
echo "The Response message is: " . $error->getResponseBody() . "\n";
}
else {
echo "Created Id={$resultingObj->Id}. Reconstructed response body:\n\n";
$xmlBody = XmlObjectSerializer::getPostXmlFromArbitraryEntity($resultingObj, $urlResource);
echo $xmlBody . "\n";
return $resultingObj->Id;
}
use QuickBooksOnline\API\DataService\DataService;
$dataService = DataService::Configure(array(
'auth_mode' => 'oauth2',
'ClientID' => 'your client id',
'ClientSecret' => 'your client secret',
'RedirectURI' =>'redirect url',
'scope' => "com.intuit.quickbooks.accounting openid profile",
'baseUrl' => 'development or production'
));
$OAuth2LoginHelper = $dataService->getOAuth2LoginHelper();
$authorizationCodeUrl = $OAuth2LoginHelper->getAuthorizationCodeURL();
if( isset($_GET['code']) ) {
$accessTokenObj = $OAuth2LoginHelper->exchangeAuthorizationCodeForToken( $_GET['code'], 'your company id') );
// save these for later use
$refreshTokenValue = $accessTokenObj->getRefreshToken();
// Expires every 12 hours.
$refreshTokenExpiry = $accessTokenObj->getRefreshTokenExpiresAt();
// The access token and access token expiration.
$accessTokenValue = $accessTokenObj->getAccessToken();
$accessTokenExpiry = $accessTokenObj->getAccessTokenExpiresAt();
}