获取交易完成后客户详细信息(Get customer details after transacti

2019-09-28 15:35发布

我挣扎宝NVP和REST API之间决定。

该REST API似乎是更新,更好,但我不能找到一个办法让客户详细信息的交易发生之后。

基本上我想建立一个结算计划的定期付款,然后通过API获得客户的详细资料,以便他们没有经过我的网站进入他们。

PayPal快速结帐似乎是什么,我应该在这里使用。

该NVP API提供了一个GetExpressCheckoutDetails方法来获取这些详细信息。

我没有找到的REST API类似的东西。

由于REST API似乎经历快速结账,以及应该有一个解决方案。

我怎样才能激活结算协议后,客户的详细信息?

Answer 1:

我在一个月前就遇到了这个同样的问题,阅读文档后,目前尚无办法用REST API来实现这一目标。 如果有一种方法,它没有记录。

我发现,要做到这一点的唯一方法是用NVP API以及可能SOAP API。 该NVP API会还给你最想要,但如果你已经保存的自定义字段用于交易,只会让你的自定义字段,但不是所有的人(怪异)的3场。

我还没有尝试过的方法NVP GetExpressCheckoutDetails ,但我已经使用了GetTransactionDetails方法。 它会给你回的交易细节。 它返回一个文本块,你必须分析。 每个字段是URL编码,并且通过&符号分隔。 下面是PHP的例子:

<?php

// Get cURL resource
$ch = curl_init();

// Set url
curl_setopt($ch, CURLOPT_URL, 'https://api-3t.paypal.com/nvp/');

// Set method
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'POST');

// Set options
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);

// Set headers
curl_setopt($ch, CURLOPT_HTTPHEADER, [
    "Content-Type: application/x-www-form-urlencoded; charset=utf-8",
    ]
);
// Create body
$body = [
    "VERSION" => "204.0",
    "METHOD" => "GetTransactionDetails",
    "USER" => "nvp_api_username_here",
    "PWD" => "nvp_api_password_here",
    "SIGNATURE" => "nvp_api_signature_here",
    "TRANSACTIONID" => "some_paypal_transaction_id_here",
];
$body = http_build_query($body);

// Set body
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $body);

// Send the request and save response to $resp
$resp = curl_exec($ch);

if(!$resp) {
    die('Error: "' . curl_error($ch) . '" - Code: ' . curl_errno($ch));
} else {
    parse_str($resp, $formated_response);
    print_r($formated_response);
}

// Close request to clear up some resources
curl_close($ch);

下面是格式化的回报体:

Array
(
    [RECEIVERBUSINESS] => paypal_account_owner_email_address_here@test.com
    [RECEIVEREMAIL] => paypal_account_owner_email_address_here@test.com
    [RECEIVERID] => 1111111111111
    [EMAIL] => buyers_email_address_here@test.com
    [PAYERID] => 55551
    [PAYERSTATUS] => verified
    [COUNTRYCODE] => US
    [BUSINESS] => buyers_business_name_here
    [ADDRESSOWNER] => PayPal
    [ADDRESSSTATUS] => None
    [SALESTAX] => 0.00
    [SHIPAMOUNT] => 0.00
    [SHIPHANDLEAMOUNT] => 0.00
    [SHIPDISCOUNT] => 0.00
    [INSURANCEAMOUNT] => 0.00
    [GIFTRECEIPT] => 0
    [TIMESTAMP] => 2016-08-02T17:04:58Z
    [CORRELATIONID] => 55552
    [ACK] => Success
    [VERSION] => 204.0
    [BUILD] => 22386173
    [FIRSTNAME] => Foo
    [LASTNAME] => Bar
    [TRANSACTIONID] => 55553
    [TRANSACTIONTYPE] => webaccept
    [PAYMENTTYPE] => instant
    [ORDERTIME] => 2016-08-01T20:49:28Z
    [AMT] => 1.00
    [TAXAMT] => 0.00
    [CURRENCYCODE] => USD
    [PAYMENTSTATUS] => Completed
    [PENDINGREASON] => None
    [REASONCODE] => None
    [SHIPPINGMETHOD] => Default
    [PROTECTIONELIGIBILITY] => Ineligible
    [PROTECTIONELIGIBILITYTYPE] => None
    [L_QTY0] => 0
    [L_TAXAMT0] => 0.00
    [L_SHIPPINGAMT0] => 0.00
    [L_HANDLINGAMT0] => 0.00
    [L_CURRENCYCODE0] => USD
    [L_OPTIONSNAME0] => first_custom_field_label_here
    [L_OPTIONSVALUE0] => first_custom_field_value_here
    [L_OPTIONSNAME1] => second_custom_field_label_here
    [L_OPTIONSVALUE1] => second_custom_field_value_here
    [L_OPTIONS1NAME0] => second_custom_field_label_here_duplicate
    [L_OPTIONS1VALUE0] => second_custom_field_value_here_duplicate
    [L_TAXABLE0] => false
    [L_TAXRATE0] => 0.0
    [L_AMT0] => 1.00
    [INSURANCEOPTIONSELECTED] => 0
    [SHIPPINGOPTIONISDEFAULT] => 0
)

警告:

仅当你存储在PayPal的交易自定义字段适用。

PayPal的API NVP只返回最多可为交易3个自定义字段,即使您最多可以存储在一个事务中7个的自定义字段。 更疯狂的,它返回的自定义字段中的一个是第二个自定义字段的副本。 至少,这样的话,当我尝试检索事务的自定义字段。



文章来源: Get customer details after transaction