PayPal API CreateRecurringPaymentsProfile отказывается работать - PullRequest
4 голосов
/ 21 октября 2011

Я искал информацию об этом за последние 5 часов и нашел много, что не работает.Я успешно смог использовать API-интерфейс setExpressCheckout, получить подробную информацию и выставить обычный заказ, но когда я хочу создать профиль повторяющегося платежа, я всегда получаю неверную ошибку токена.Я знаю, что это не недействительный токен, но я не знаю, что делать.

В настоящее время я использую пример кода PayPal для setExpressCheckout и createRecurringPaymentsProfile, но без успеха.

Вот мой смехотворно упрощенныйкод от PayPal.

<?

$environment = 'sandbox';   // or 'beta-sandbox' or 'live'
$ROOT_URL = 'http://example.com/paypal/';

/**
 * Send HTTP POST Request
 *
 * @param   string  The API method name
 * @param   string  The POST Message fields in &name=value pair format
 * @return  array   Parsed HTTP Response body
 */
function PPHttpPost($methodName_, $nvpStr_) {

    global $environment;

    $API_UserName = urlencode('email');
    $API_Password = urlencode('pass');
    $API_Signature = urlencode('sig');
    $API_Endpoint = "https://api-3t.paypal.com/nvp";
    if("sandbox" === $environment || "beta-sandbox" === $environment) {
        $API_Endpoint = "https://api-3t.$environment.paypal.com/nvp";
    }
    $version = urlencode('51.0');

    // setting the curl parameters.
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $API_Endpoint);
    curl_setopt($ch, CURLOPT_VERBOSE, 1);

    // turning off the server and peer verification(TrustManager Concept).
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);

    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_POST, 1);

    // NVPRequest for submitting to server
    $nvpreq = "METHOD=$methodName_&VERSION=$version&PWD=$API_Password&USER=$API_UserName&SIGNATURE=$API_Signature$nvpStr_";

    // setting the nvpreq as POST FIELD to curl
    curl_setopt($ch, CURLOPT_POSTFIELDS, $nvpreq);

    // getting response from server
    $httpResponse = curl_exec($ch);

    if(!$httpResponse) {
        exit("$methodName_ failed: ".curl_error($ch).'('.curl_errno($ch).')');
    }

    // Extract the RefundTransaction response details
    $httpResponseAr = explode("&", $httpResponse);

    $httpParsedResponseAr = array();
    foreach ($httpResponseAr as $i => $value) {
        $tmpAr = explode("=", $value);
        if(sizeof($tmpAr) > 1) {
            $httpParsedResponseAr[$tmpAr[0]] = $tmpAr[1];
        }
    }

    if((0 == sizeof($httpParsedResponseAr)) || !array_key_exists('ACK', $httpParsedResponseAr)) {
        exit("Invalid HTTP Response for POST request($nvpreq) to $API_Endpoint.");
    }

    return $httpParsedResponseAr;
}


 $paymentAmount = urlencode(34.00);
if(!isset($_REQUEST['token'])){  
     // Set request-specific fields.

    $currencyID = urlencode('USD');                         // or other currency code ('GBP', 'EUR', 'JPY', 'CAD', 'AUD')
    $paymentType = urlencode('Authorization');              // or 'Sale' or 'Order'

    $returnURL = urlencode($ROOT_URL.'/buy.php?return=1');
    $cancelURL = urlencode($ROOT_URL.'/buy.php?cancel=1');

    // Add request-specific fields to the request string.
    $nvpStr = "&Amt=$paymentAmount&ReturnUrl=$returnURL&CANCELURL=$cancelURL&PAYMENTACTION=$paymentType&CURRENCYCODE=$currencyID";

    // Execute the API operation; see the PPHttpPost function above.
    $httpParsedResponseAr = PPHttpPost('SetExpressCheckout', $nvpStr);

    print_r($httpParsedResponseAr);

    if("SUCCESS" == strtoupper($httpParsedResponseAr["ACK"]) || "SUCCESSWITHWARNING" == strtoupper($httpParsedResponseAr["ACK"])) {
        // Redirect to paypal.com.
        $token = urldecode($httpParsedResponseAr["TOKEN"]);
        $payPalURL = "https://www.paypal.com/webscr&cmd=_express-checkout&token=$token";
        if("sandbox" === $environment || "beta-sandbox" === $environment) {
            $payPalURL = "https://www.$environment.paypal.com/webscr&cmd=_express-checkout&token=$token";
        }

        //header("Location: $payPalURL");
        echo '<a href="'.$payPalURL.'">PayPal</a>';
        exit;
    } else  {
        exit('SetExpressCheckout failed: ' . print_r($httpParsedResponseAr, true));
    }
}else{
    $token = urlencode($_REQUEST['token']);
    //Now create recurring profile
    ?>
    <h1>Yes!</h1>
    <?


$currencyID = urlencode("USD");                     // or other currency code ('GBP', 'EUR', 'JPY', 'CAD', 'AUD')
$startDate = urlencode("2012-9-6T0:0:0");
$billingPeriod = urlencode("Month");                // or "Day", "Week", "SemiMonth", "Year"
$billingFreq = urlencode("4");                      // combination of this and billingPeriod must be at most a year

$nvpStr="&TOKEN=$token&AMT=$paymentAmount&CURRENCYCODE=$currencyID&PROFILESTARTDATE=$startDate";
$nvpStr .= "&BILLINGPERIOD=$billingPeriod&BILLINGFREQUENCY=$billingFreq";

$httpParsedResponseAr = PPHttpPost('CreateRecurringPaymentsProfile', $nvpStr);

if("SUCCESS" == strtoupper($httpParsedResponseAr["ACK"]) || "SUCCESSWITHWARNING" == strtoupper($httpParsedResponseAr["ACK"])) {
    exit('CreateRecurringPaymentsProfile Completed Successfully: '.print_r($httpParsedResponseAr, true));
} else  {
    exit('CreateRecurringPaymentsProfile failed: ' . print_r($httpParsedResponseAr, true));
}
}
?>

Очевидно, что адрес электронной почты, пароль и подпись здесь неверны.Мой сценарий называется example.com/paypal/buy.php. Если это неясно ...

ОБНОВЛЕНИЕ: Я наконец-то нашел что-то, что работает.У меня пока нет красивого кода, но он, по крайней мере, прошел.https://www.x.com/developers/paypal/forums/nvp/createrecurringpaymentsprofile-invalid-token-0

1 Ответ

6 голосов
/ 13 ноября 2012

Ты уже все понял? Причина, по которой вы получите неверную ошибку токена, заключается в том, что вы не включили информацию соглашения о выставлении счетов (повторяющиеся платежи) в свой запрос SetExpressCheckout.

Вот выборочный набор , который я всегда использую, чтобы показать людям, когда возникает этот вопрос. Обратите внимание на BILLINGTYPE и BILLINGAGREEMENTDESCRIPTION, включенные в SEC.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...