Php Quick Books创建客户OAuth 2.0令牌错误

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中抛出,请参考: 我做错了什么

我得到这个错误

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();
}