2013-04-21 2 views
0

성공적인 전송을 위해 트랜잭션 데이터를 가져 와서이를 mysql 테이블에 저장하는 Paypal IPN 스크립트가 있습니다. 하지만이 거래의 페이팔 금액을 내 사이트의 회원 잔액으로 추가하고 싶습니다.Paypal IPN 변수가 추가 및 업데이트되지 않음

<?php 
session_start(); 
if (!isset($_SESSION['Email'])) { 
header('Location: mainerror.php'); 
} 
$Email=$_SESSION['Email']; 
    $connn = mysql_connect("localhost","******","*******"); 
if (!$connn) 
    { 
    die('Could not connect: ' . mysql_error()); 
    } 

mysql_select_db("********", $connn); 
     $result1 = mysql_query("SELECT * from members WHERE Email='$Email' "); 
//Use the mysql_fetch_array function on the resource returned by the mysql_query 
$row1 = mysql_fetch_assoc($result1); 
$old = $row1['balance']; 
// STEP 1: Read POST data 

// reading posted data from directly from $_POST causes serialization 
// issues with array data in POST 
// reading raw POST data from input stream instead. 
$raw_post_data = file_get_contents('php://input'); 
$raw_post_array = explode('&', $raw_post_data); 
$myPost = array(); 
foreach ($raw_post_array as $keyval) { 
    $keyval = explode ('=', $keyval); 
    if (count($keyval) == 2) 
    $myPost[$keyval[0]] = urldecode($keyval[1]); 
} 
// read the post from PayPal system and add 'cmd' 
$req = 'cmd=_notify-validate'; 
if(function_exists('get_magic_quotes_gpc')) { 
    $get_magic_quotes_exists = true; 
} 
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"; 
} 


// STEP 2: Post IPN data back to paypal to validate 

$ch = curl_init('https://www.sandbox.paypal.com/cgi-bin/webscr'); 
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')); 

// In wamp like environments that do not come bundled with root authority certificates, 
// please download 'cacert.pem' from "http://curl.haxx.se/docs/caextract.html" and set the directory path 
// of the certificate as shown below. 
// curl_setopt($ch, CURLOPT_CAINFO, dirname(__FILE__) . '/cacert.pem'); 
if(!($res = curl_exec($ch))) { 
    // error_log("Got " . curl_error($ch) . " when processing IPN data"); 
    curl_close($ch); 
    exit; 
} 
curl_close($ch); 


// STEP 3: Inspect IPN validation result and act accordingly 

if (strcmp ($res, "VERIFIED") == 0) { 
    // check whether the payment_status is Completed 
    // check that txn_id has not been previously processed 
    // check that receiver_email is your Primary PayPal email 
    // check that payment_amount/payment_currency are correct 
    // process payment 

    // assign posted variables to local variables 
    $payment_currency = $_POST['mc_currency']; 
    $txn_id = $_POST['txn_id']; 
$address_zip = $_POST['address_zip']; 
$address_country = $_POST['address_country_code']; 
$payment_date = $_POST['payment_date']; 
    $payer_email = $_POST['payer_email']; 
    $first_name = $_POST['first_name']; 
    $last_name = $_POST['last_name']; 
    $item_name = $_POST['item_name']; 
    $item_number = $_POST['item_number']; 
    $payment_status = $_POST['payment_status']; 
    $payment_amount = $_POST['mc_gross']; 


$con=mysqli_connect("localhost","******","******","*******"); 

// Check connection 
if (mysqli_connect_errno()) 
    { 
    echo "Failed to connect to MySQL: " . mysqli_connect_error(); 
    } 

mysqli_query($con,"INSERT INTO sales (item_name, item_number, payment_status, mc_gross, mc_currency, txn_id, payer_email, first_name, last_name, payment_date, address_zip, address_country) 
VALUES ('$item_name', '$item_number', '$payment_status', '$payment_amount', '$payment_currency', '$txn_id', '$payer_email', '$first_name', '$last_name', '$payment_date', '$address_zip', '$address_country')"); 

$new = ($old + $payment_amount); 
mysqli_query($con,"UPDATE members SET balance='$new' 
WHERE Email='$payer_email'"); 
mysqli_close($con); 

} else if (strcmp ($res, "INVALID") == 0) { 
    // log for manual investigation 
} 
?> 

거래에서 $ payment_amount로 현재 회원 금액 인 $ old amount를 추가하고 싶습니다. 하지만 마침내 회원 테이블에서 $ payment_amount 만 업데이트됩니다.

+0

처럼 보이는 것처럼 당신은 당신이 값을 가져옵니다 확신가 someting, 당신의 삽입 쿼리 후 나는 members 테이블에서 이전 양을 얻을 것하고 새로운 양의 데이터로 업데이트 '$ old' 변수? – GBD

답변

1

$old 변수가 어디에도 정의되어 있지 않은 것처럼 보였으므로 다른 접근 방식을 사용하게됩니다.

$query = mysqli_query($con,"SELECT balance FROM members WHERE Email='$payer_email'"); 
if($row = mysqli_fetch_array($query)) 
{ 
    $sql = mysqli_query($con, "UPDATE members SET balance = '".$row['balance'] + $payment_amount."' WHERE Email = '$payer_email'"); 
} 

그래서 코드가

mysqli_query($con,"INSERT INTO sales (item_name, item_number, payment_status, mc_gross, mc_currency, txn_id, payer_email, first_name, last_name, payment_date, address_zip, address_country) VALUES ('$item_name', '$item_number', '$payment_status', '$payment_amount', '$payment_currency', '$txn_id', '$payer_email', '$first_name', '$last_name', '$payment_date', '$address_zip', '$address_country')"); 

$query = mysqli_query($con,"SELECT balance FROM members WHERE Email='$payer_email'"); 
if($row = mysqli_fetch_array($query)) 
{ 
    $sql = mysqli_query($con, "UPDATE members SET balance = '".$row['balance'] + $payment_amount."' WHERE Email = '$payer_email'"); 
} 

mysqli_close($con); 

} else if (strcmp ($res, "INVALID") == 0) { 
    // log for manual investigation 
} 
+0

고맙습니다. 너 나 많이 도와 줬어. 그것은 일했습니다 ... –

+0

@AkashSharma 좋은데, 당신은 환영합니다. 비슷한 문제가있는 다른 사람들도 도와 줄 수 있도록 답변을 수락하십시오 – Fabio

+0

@ Fabio Accept –