2013-07-18 10 views
6

私はサンドボックスモードを試してみるために開発者のビジネスアカウントと個人アカウントを設定しました。Paypal IPNサンドボックス - IPNリスナー - 検証済みまたは無効です

私は自分のサイトで支払いボタンを作った。私はボタンをクリックし、ペイパルに行く。 テストユーザーの個人アカウントが支払いに使用されます。 ペイパルのビジネスアカウントを見ると、支払いが完了し完了します。 私のサイトにリダイレクトするとうまくいきます。

私の目には、私は "働く"システムが必要です。

私のIPNリスナーは、検証済みか無効かのどちらかを返しません。

これは私のリスナーです:

<?php 
require("../widgets/init.inc.php"); 

//Test the script is launced 
$log_query = mysql_query("INSERT INTO `log` VALUES (' ','zz','ff','rr', 'rr')");     

// Link to PayPal Codes // 
// https://cms.paypal.com/us/cgi-bin/?cmd=_render-content&content_ID=developer/e_howto_html_IPNandPDTVariables // 

// read the post from PayPal system and add 'cmd' // 
$req = 'cmd=_notify-validate'; 

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"; 

//For the below line i have tried "www.sandbox.paypal" as well as "www.paypal" 
$fp = fsockopen ('ssl://www.paypal.com', 443, $errno, $errstr, 30); 

// assign posted variables to local variables // 
$item_name = $_POST['item_name']; 
$item_number = $_POST['item_number']; 
$payment_status = $_POST['payment_status']; 
$payment_amount = $_POST['mc_gross']; 
$payment_currency = $_POST['mc_currency']; 
$txnId = $_POST['txn_id']; 
$receiverEmail = $_POST['receiver_email']; 
$payerEmail = $_POST['payer_email']; 
//$id = ($_POST['custom']); 

if (!$fp) { 

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

if ($payment_status=='Completed') { 

//$txnIdCheck = mysql_query("SELECT `txnId` FROM `log` WHERE `txnId`='".$txnId."'"); 
//if (mysql_num_rows($txnIdCheck) !=1) { 

// enter your email address associated with your paypal account here // 
if ($receiverEmail=='[email protected]') { 

/* when a new premium member makes payment paypal will update our database. The txn_id from paypal, members email address, date of payment and members id we gave them when they joined our site will be inserted into the log table. At the same time the memberAdmin table for the member will be updated by adding a '1' to premium and the date of payment so the new premium member will have access to premium areas of your site. */ 

//Check if verified is launced   
$log_query_2 = mysql_query("INSERT INTO `log` VALUES (' ','yes','yes','yes', 'yes')");   

//$log_query = mysql_query("INSERT INTO `log` VALUES (' ','".intval($id)."','".$txnId."','".$payerEmail."', now())");     

//$update_premium = mysql_query("UPDATE `memberAdmin` SET `premium`=1, `premiumDate`=now() WHERE `id`=".intval($id)."");  

}  
//} 
} 
} 
else if (strcmp ($res, "INVALID") == 0) {   
//Check if invalid is launced 
$log_query_2 = mysql_query("INSERT INTO `log` VALUES (' ','no','no','no', 'no'"); 
} 
} 
fclose ($fp); 
} 
?> 

私はPayPalのビジネスアカウントサイトでIPNが有効になっています。 私はペイパルから返される情報のtxtファイルを作ってきた、それは次のようになります。

==== Thu, 18 Jul 2013 01:34:21 +0200 ==== 
POST: mc_gross = 0.01 
POST: protection_eligibility = Ineligible 
POST: payer_id = 73WPPK8HKSW7C 
POST: tax = 0.00 
POST: payment_date = 15:15:20 Jul 17, 2013 PDT 
POST: payment_status = Completed 
POST: charset = windows-1252 
POST: first_name = Niels 
POST: mc_fee = 0.01 
POST: notify_version = 3.7 
POST: payer_status = verified 
POST: business = [email protected] 
POST: quantity = 1 
POST: verify_sign = A-ddKAwtxju4TpHGJOGq6c3ewj26AyiHsD.XO90coZ.4rVzOT7VyooKO 
POST: payer_email = [email protected] 
POST: txn_id = 6WH41489RE087103M 
POST: payment_type = instant 
POST: last_name = Tester 
POST: receiver_email = [email protected] 
POST: payment_fee = 0.01 
POST: receiver_id = PCX638B2M7WPA 
POST: txn_type = web_accept 
POST: item_name = 500Credits 
POST: mc_currency = USD 
POST: item_number = 1 
POST: residence_country = DE 
POST: test_ipn = 1 
POST: handling_amount = 0.00 
POST: transaction_subject = 500Credits 
POST: payment_gross = 0.01 
POST: shipping = 0.00 
POST: ipn_track_id = 2dffcbf8767d3 
InvoiceID: 
Custom1: 
Custom2: 
Custom3: 

私はそれがあるべきだと思う何よりも、この作業を取得するために多くの困難であるように思え。

答えて

13

私は問題を見つけました。そして、アナウンスしているのはペイパル書類が間違っているということです。ドキュメンテーションがこのボタンを押してこのボタンを押すと理解できません。このようなボタンがないときサイト...

この問題の原因 - ドキュメントには間違った方法が記載されているか、必要な完全なコードは含まれていません。

は問題:追加する必要があるもの

HTTP/1.0 400 Bad Request 
Server: BigIP 
Connection: close 
Content-Length: 19 
Invalid Host header 

は次のとおりです:

$header .= "Host: www.sandbox.paypal.com\r\n"; 

、その後、上記のコードは次のようになります。

// post back to PayPal system to validate // 
$header .= "POST /cgi-bin/webscr HTTP/1.0\r\n"; 
$header .= "Host: www.sandbox.paypal.com\r\n"; 
$header .= "Content-Type: application/x-www-form-urlencoded\r\n"; 
$header .= "Content-Length: " . strlen($req) . "\r\n\r\n"; 
$fp = fsockopen ('ssl://www.sandbox.paypal.com', 443, $errno, $errstr, 30); 
$ resが、これを返さ

これは私が使用した最後の完全なコードでした:

<?php 
require("../widgets/init.inc.php");   

// Link to PayPal Codes // 
// https://cms.paypal.com/us/cgi-bin/?cmd=_render-content&content_ID=developer/e_howto_html_IPNandPDTVariables // 

// read the post from PayPal system and add 'cmd' // 
$req = 'cmd=_notify-validate'; 

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 .= "Host: www.sandbox.paypal.com\r\n"; 
$header .= "Content-Type: application/x-www-form-urlencoded\r\n"; 
$header .= "Content-Length: " . strlen($req) . "\r\n\r\n"; 
$fp = fsockopen ('ssl://www.sandbox.paypal.com', 443, $errno, $errstr, 30); 

// assign posted variables to local variables // 
$item_name = $_POST['item_name']; 
$item_number = $_POST['item_number']; 
$payment_status = $_POST['payment_status']; 
$payment_amount = $_POST['mc_gross']; 
$payment_currency = $_POST['mc_currency']; 
$txnId = $_POST['txn_id']; 
$receiverEmail = $_POST['receiver_email']; 
$payerEmail = $_POST['payer_email']; 
//$id = ($_POST['custom']); 


if (!$fp) { 

} else { 
fputs ($fp, $header . $req); 
while (!feof($fp)) { 
$res = fgets ($fp, 1024); 

$log_query_pre = mysql_query("INSERT INTO `log` VALUES (' ','$receiverEmail','$payment_status','$res', 'yes')");  

    if (strcmp ($res, "VERIFIED") == 0) { 

if ($payment_status=='Completed') { 

//$txnIdCheck = mysql_query("SELECT `txnId` FROM `log` WHERE `txnId`='".$txnId."'"); 
//if (mysql_num_rows($txnIdCheck) !=1) { 

// enter your email address associated with your paypal account here // 
if ($receiverEmail=='[email protected]') { 

/* when a new premium member makes payment paypal will update our database. The txn_id from paypal, members email address, date of payment and members id we gave them when they joined our site will be inserted into the log table. At the same time the memberAdmin table for the member will be updated by adding a '1' to premium and the date of payment so the new premium member will have access to premium areas of your site. */ 

//Check if verified is launced   
$log_query_2 = mysql_query("INSERT INTO `log` VALUES (' ','yes','yes','yes', 'yes')");  

//$log_query = mysql_query("INSERT INTO `log` VALUES (' ','".intval($id)."','".$txnId."','".$payerEmail."', now())");     

//$update_premium = mysql_query("UPDATE `memberAdmin` SET `premium`=1, `premiumDate`=now() WHERE `id`=".intval($id)."");  

}  
//} 
} 
} 
else if (strcmp ($res, "INVALID") == 0) {   
//Check if invalid is launced 
$log_query_2 = mysql_query("INSERT INTO `log` VALUES (' ','no','no','no', 'no')"); 
} 
} 
fclose ($fp); 
} 
?> 
+1

ありがとうございました!私は午後すべて同じ問題を抱えてきました。私はこれを見つけてうれしい。それはドキュメントのエラーだと恥ずかしい... –

+1

ありがとう!私はまったく同じ問題を抱えていました。 – oliverbj

+0

@Niels上記の手順に従っていますが、$ resはHTTP/1.1 200を返しています。OK、どのようにしてVERIFIEDまたはINVALIDメッセージを取得できますか? – oletob