2

製品を販売するために、自分の Web サイトで PayPal の [今すぐ購入] ボタンを使用しています。MySQL データベースで各製品の在庫数を追跡しており、システムの在庫追跡を自動化したいので、PayPal の即時支払い通知機能を使用して、購入がいつ行われたかを知らせています。完了しました。Paypal がハンドラーに有効な購入が行われたことを通知すると、スクリプトは購入した製品の在庫から「1」を差し引いて MySQL データベースを更新します。

Paypal の今すぐ購入ボタン (一度に 1 つの購入) で正常に動作する IPN PHP コードを以下に添付しました。

私の質問は、顧客が一度に複数の製品を購入できるように、「今すぐ購入」ボタンを PayPal の「カートに追加」ボタンに置​​き換えたいということです。以下のコードを変更して、購入したすべてのアイテムをループさせ、それに応じてデータベースを更新する方法がわかりません。どんな助けでも大歓迎です!

コード:

    // Paypal POSTs HTML FORM variables to this page
// we must post all the variables back to paypal exactly unchanged and add an extra parameter cmd with value _notify-validate

// initialise a variable with the requried cmd parameter
$req = 'cmd=_notify-validate';

// go through each of the POSTed vars and add them to the variable
foreach ($_POST as $key => $value) {
$value = urlencode(stripslashes($value));
$req .= "&$key=$value";
}

// post back to PayPal system to validate
$header .= "POST /cgi-bin/webscr HTTP/1.0\r\n";
$header .= "Content-Type: application/x-www-form-urlencoded\r\n";
$header .= "Content-Length: " . strlen($req) . "\r\n\r\n";

// In a live application send it back to www.paypal.com
// but during development you will want to uswe the paypal sandbox

// comment out one of the following lines

$fp = fsockopen ('www.sandbox.paypal.com', 80, $errno, $errstr, 30);
//$fp = fsockopen ('www.paypal.com', 80, $errno, $errstr, 30);

// or use port 443 for an SSL connection
//$fp = fsockopen ('ssl://www.paypal.com', 443, $errno, $errstr, 30);


if (!$fp) {
// HTTP ERROR
}
else
{
  fputs ($fp, $header . $req);
  while (!feof($fp)) {
    $res = fgets ($fp, 1024);
    if (strcmp ($res, "VERIFIED") == 0) {


      $item_name = stripslashes($_POST['item_name']);
      $item_number = $_POST['item_number'];
      $item_id = $_POST['custom'];  
      $payment_status = $_POST['payment_status'];
      $payment_amount = $_POST['mc_gross'];         //full amount of payment. payment_gross in US
      $payment_currency = $_POST['mc_currency'];
      $txn_id = $_POST['txn_id'];                   //unique transaction id
      $receiver_email = $_POST['receiver_email'];
      $payer_email = $_POST['payer_email'];
      $size = $_POST['option_selection1'];
      $item_id  = $_POST['item_id'];
      $business = $_POST['business'];



      if ($payment_status == 'Completed')  {  
// UPDATE THE DATABASE      


      }
4

2 に答える 2

1

おそらく、すべてのアイテム ID を注文 ID にまとめて、その注文 ID を POST で PayPal に送信する方が簡単でしょう。IPN があなたの詳細を返送したら、注文 ID のすべてのアイテムの合計額が、IPN が支払った金額と一致することを確認して計算します。

データベースに注文 ID を照会し、それに接続されているすべてのアイテム ID を取得してから、各アイテム ID の在庫数を減らします。

それが役に立てば幸い。それはそれを行うための1つの方法です!

于 2010-04-16T06:34:08.473 に答える
0

あなたが何を求めているのかは明らかではありません。Web Payment Pro 用の PayPal IPN リスナーを作成しました。まず、 PayPal のドキュメント: IPN サンプル コードを参照し、必要に応じてコードを変更しました。質問にさらに詳細を追加してください。

于 2010-04-16T02:47:27.417 に答える