快速结账的基本Paypal Sandbox授权和捕获逻辑

时间:2015-01-13 00:15:27

标签: php paypal-sandbox paypal

我不理解或不在文档的错误部分。这是我第一次做出超出基本IPN响应的任何事情。

我设置了一个开发人员帐户,其中包含所有凭据,包括签名。我的整个网站都是PHP,我希望使用单一功能进行所有Paypal授权和捕获。我现在正在编写此函数,并且只具有以下非动态功能

function testHandler()
{
    if ( function_exists('get_magic_quotes_gpc') ) { $get_magic_quotes_exists = true; }

    $req = '';

    $myPost = array(
    'USER'                          => 'USER',
    'PWD'                           => 'PASSWORD',
    'SIGNATURE'                     => 'SIGNATURE',
    'METHOD'                        => 'SetExpressCheckout',
    //'METHOD'                        => 'GetExpressCheckoutDetails',
    //'TOKEN' => 'EC-XXXXXXXXXXXX', 
    'VERSION'                       => '95'
    'PAYMENTREQUEST_0_PAYMENTACTION'=> 'Authorization', #Sets up authorization for a single future payment
    'PAYMENTREQUEST_0_AMT'          => '1', #The amount authorized
    'PAYMENTREQUEST_0_CURRENCYCODE' => 'USD', #The currency, e.g. US dollars
    'cancelUrl'                     => 'http://www.yourdomain.com/cancel.html',
    'returnUrl'                     => 'http://www.yourdomain.com/success.html' 
    );

    foreach ( $myPost as $key => $value )
    {
        if ( $get_magic_quotes_exists == true && get_magic_quotes_gpc() == 1 )
        {
            $value = urlencode(stripslashes($value));
        }
        else
        {
            $value = urlencode($value);
        }

        $req .= "&$key=$value";
    }

    $ch = curl_init( 'https://api-3t.sandbox.paypal.com/nvp' );
    curl_setopt( $ch, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_1) ;
    curl_setopt( $ch, CURLOPT_POST, 1) ;
    curl_setopt( $ch, CURLOPT_RETURNTRANSFER, 1 );
    curl_setopt( $ch, CURLOPT_POSTFIELDS, $req );
    curl_setopt( $ch, CURLOPT_SSL_VERIFYPEER, 1 );
    curl_setopt( $ch, CURLOPT_SSL_VERIFYHOST, 2 );
    curl_setopt( $ch, CURLOPT_FORBID_REUSE, 1 );
    curl_setopt( $ch, CURLOPT_HTTPHEADER, array('Connection: Close') );

    if(  !( $res = curl_exec($ch) ) ) { curl_close($ch); exit; }

    curl_close($ch);

    return $res;
}

首先,这是我需要的所有后端吗?提供$ myPost的内容是根据我们在此过程中的任何步骤而定制的。

我已在我的服务器上运行此脚本,但它确实返回了一个令牌。我手动输入令牌以模拟正在重定向的客户,并且我看到一个空白的结帐页面,因为在任何时候都没有通过任何项目详细信息。

https://www.sandbox.paypal.com/cgi-bin/webscr?cmd=_express-checkout&token=EC-XXXXXXXX

在创建像标准快速结账变量这样的令牌时,我是否应该在$ myPost中包含订单详情? item_name等。即使这样价格已经过去了,为什么不出现?结帐页面的摘要完全没有。

接下来,需要注释掉的$ myPost部分才能使用GetExpressCheckoutDetails检索payerID。

当我尝试运行该代码步骤时,我得到了这个回复

TOKEN=EC%2dXXXXXXXXXX&BILLINGAGREEMENTACCEPTEDSTATUS=0&CHECKOUTSTATUS=PaymentActionNotInitiated&TIMESTAMP=2015%2d01%2d12T22%3a47%3a01Z&CORRELATIONID=403d2feb197db&ACK=Success&VERSION=95&BUILD=14726230&CURRENCYCODE=USD&AMT=1%2e00&SHIPPINGAMT=0%2e00&HANDLINGAMT=0%2e00&TAXAMT=0%2e00&INSURANCEAMT=0%2e00&SHIPDISCAMT=0%2e00&PAYMENTREQUEST_0_CURRENCYCODE=USD&PAYMENTREQUEST_0_AMT=1%2e00&PAYMENTREQUEST_0_SHIPPINGAMT=0%2e00&PAYMENTREQUEST_0_HANDLINGAMT=0%2e00&PAYMENTREQUEST_0_TAXAMT=0%2e00&PAYMENTREQUEST_0_INSURANCEAMT=0%2e00&PAYMENTREQUEST_0_SHIPDISCAMT=0%2e00&PAYMENTREQUEST_0_INSURANCEOPTIONOFFERED=false&PAYMENTREQUESTINFO_0_ERRORCODE=0

这是有道理的,因为没有输入付款信息。我是否应该在Sandbox期间输入真实的财务信息以进入下一步?我是否应该从客户处收集它并在创建令牌时将其传递给我?我在哪里可以访问此创建的令牌并强制执行下一步?

如果这是实时的并且我能够传递商品详细信息以便结帐页面不空白,则客户会输入他们的详细信息并被重定向到页面后面的URL中的令牌。那时我可以使用GetExpressCheckoutDetails令牌并检索PayerID吗?使用PayerID,我可以使用DoExpressCheckoutPayment获取最终付款捕获的交易ID吗?

感谢您阅读

1 个答案:

答案 0 :(得分:1)

听起来你已经掌握了它的要点。 Express Checkout包含3个独立的API调用:SetExpressCheckoutGetExpressCheckoutDetailsDoExpressCheckoutPayment

SEC只是该过程的第一步,是的,您可以在调用中包含更多参数,以便显示所有订单数据并按预期使用,如您在前面的链接中所见。

在最终的DECP呼叫完成之前,不会移动任何资金,只有该请求中包含的详细信息将被保存并通过PayPal系统传递。