Paypal API NVP错误消息:如果提供了项目类别,则需要项目名称,数量和数量

时间:2014-01-14 01:34:17

标签: php mysql paypal paypal-nvp

有人可以帮忙解决这个问题。我一直收到以下错误消息;

  

SetExpressCheckout API调用失败。详细错误消息:项目名称,   如果提供项目类别,则需要数量和数量   错误消息:缺少argumentError代码:10003错误严重代码:   错误“

require_once ("paypalfunctions.php");

$task = $_GET['task'];
$regRef = $_SESSION['regRef'];

if(strcmp($task, "paypal") == 0) {

    $totalAmount = $_SESSION["netAmount"];
    $vatAmount = number_format((floor($totalAmount * 0.20)), 2, '.', '');
    $grossAmount = number_format(($totalAmount + $vatAmount), 2, '.', '');

    $currencyCodeType = "GBP";
    $paymentType = "Sale";

    $returnURL = "https://myurl.com/events/confirm_registration";

    $cancelURL = "http://myurl.com/events/checkout-handle.php?task=cancel";

    $host = "******";
    $dbuser = "******";
    $pass = "******";
    $db = "******";
    $connection = mysql_connect($host, $dbuser, $pass) or die ("Unable to connect!");
    mysql_select_db($db) or die ("Unable to select database!");

    mysql_query("UPDATE registrations SET `status`='paypal' WHERE `regRef`='$regRef'") or die ("Error in query: $query.".mysql_error());

    $queryItems = mysql_query("SELECT `eventName`, `itemPrice`, COUNT(*) FROM orders WHERE `regRef`='$regRef' GROUP BY `itemPrice`") or die ("Error in query: $query.".mysql_error());
    $numItems = mysql_num_rows($queryItems);
    $items = array();
    while($row = mysql_fetch_array($queryItems)) {
        $localVat = $row['itemPrice']*0.2;
        $items[] = array('name' => $row['eventName'], 'amt' => $row['itemPrice'], 'qty' => $row['COUNT(*)'], 'vat' => $localVat);   
    }
    mysql_close($connection);


    $resArray = SetExpressCheckoutDG($grossAmount, $paymentType, $vatAmount, $returnURL, $cancelURL, $currencyCodeType, $items);

这就是paypalfunctions.php文件中的内容

$PROXY_HOST = '127.0.0.1';
$PROXY_PORT = '808';

$SandboxFlag = false;

$API_UserName="******";
$API_Password="******";
$API_Signature="******";


// BN Code  is only applicable for partners
$sBNCode = "PP-ECWizard";


if ($SandboxFlag == true) 
{
    $API_Endpoint = "https://api-3t.sandbox.paypal.com/nvp";
    $PAYPAL_URL = "https://www.sandbox.paypal.com/webscr?cmd=_express-checkout&token=";
}
else
{
    $API_Endpoint = "https://api-3t.paypal.com/nvp";
    $PAYPAL_URL = "https://www.paypal.com/cgi-bin/webscr?cmd=_express-checkout&token=";
}

$USE_PROXY = false;
$version="93";

if (session_id() == "") 
    session_start();

function SetExpressCheckoutDG( $grossAmount, $paymentType, $vatAmount, $returnURL, $cancelURL, $currencyCodeType, $items ) 
{
    $itemsTotal = 0;
    $vatTotal = 0;

    foreach($items as $index => $item) 
    {
        $nvpstr .= "&L_PAYMENTREQUEST_0_NAME" . $index . "=" . urlencode($item["name"]);
        $nvpstr .= "&L_PAYMENTREQUEST_0_AMT" . $index . "=" . urlencode($item["amt"]);
        $nvpstr .= "&L_PAYMENTREQUEST_0_QTY" . $index . "=" . urlencode($item["qty"]);
        $nvpstr .= "&L_PAYMENTREQUEST_0_TAXAMT" . $index . "=" . urlencode($item["vat"]);
        $nvpstr .= "&L_PAYMENTREQUEST_0_ITEMCATEGORY" . $index . "=Physical";
        $nvpstr .= "&L_PAYMENTREQUEST_0_DESC" . $index . "=APN Event";
        $itemsTotal = $itemsTotal + ($item["amt"] * $item["qty"]);
        $vatTotal = $vatTotal + ($item["vat"] * $item["qty"]);
    }       
    $nvpstr .= "&PAYMENTREQUEST_0_ITEMAMT=" . $itemsTotal;          
    $nvpstr .= "&PAYMENTREQUEST_0_TAXAMT=" . $vatTotal;             //tax amount
    $nvpstr .= "&PAYMENTREQUEST_0_AMT=". $grossAmount;              //total cost of items inc tax
    $nvpstr .= "&PAYMENTREQUEST_0_PAYMENTACTION=" . $paymentType;
    $nvpstr .= "&RETURNURL=" . $returnURL;
    $nvpstr .= "&CANCELURL=" . $cancelURL;
    $nvpstr .= "&PAYMENTREQUEST_0_CURRENCYCODE=" . $currencyCodeType;
    $nvpstr .= "&REQCONFIRMSHIPPING=0";
    $nvpstr .= "&NOSHIPPING=1";

    $_SESSION["currencyCodeType"] = $currencyCodeType;    
    $_SESSION["PaymentType"] = $paymentType;


    $resArray=hash_call("SetExpressCheckout", $nvpstr);
    $ack = strtoupper($resArray["ACK"]);
    if($ack=="SUCCESS" || $ack=="SUCCESSWITHWARNING")
    {
        $token = urldecode($resArray["TOKEN"]);
        $_SESSION['TOKEN']=$token;
    }

    return $resArray;
}

感谢任何帮助。 :)

1 个答案:

答案 0 :(得分:1)

错误是其中一个事件的价格为0导致了问题。通过在填充数组之前添加测试为零来修复。根据paypals文档,您不能只传递0正数或负数。