Я использую кнопки «купить сейчас» PayPal на моем веб-сайте для продажи товаров. Поскольку я отслеживаю количество единиц на складе для каждого продукта в базе данных MySQL и хочу, чтобы отслеживание запасов в системе было автоматизировано, я использую функцию мгновенного уведомления PayPal, чтобы сообщить мне, когда была совершена покупка. завершено. Когда Paypal уведомляет моего обработчика о том, что была совершена покупка, скрипт обновляет мою базу данных MySQL, вычитая «1» из инвентаря приобретенного продукта.
Я приложил ниже свой PHP-код IPN, который успешно работает с кнопками PayPal «Купить сейчас» (по одной покупке за раз).
Мой вопрос: я хотел бы заменить кнопки «купить сейчас» кнопками 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
}