- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
paypal IPN不知为何没有将数据输入mysql数据库!!我正在使用 paypal 沙盒,付款通过并显示在我的沙盒帐户中,但详细信息不会显示在 mysql 中!!
这是我的 IPN 文件。尽管我将其命名为 payments.php 并且我还使用 IPN 模拟器指向它并且它确实表示 IPN 已成功发送。所以我不知道这里的问题是什么:
<?php
// Database variables
$host = "localhost"; //database location
$user = "my details"; //database username
$pass = "pass"; //database password
$db_name = "my details"; //database name
// PayPal settings
$paypal_email = 'MYSANDBOXEMAIL@PAYPAL.COM';
$return_url = 'http://some site/';
$cancel_url = 'http://some site/';
$notify_url = 'http://some site/thanks.php';
$item_name = 'Test Item';
$item_amount = 5.00;
// Include Functions
include("functions.php");
//Database Connection
$link = mysql_connect($host, $user, $pass);
mysql_select_db($db_name);
// Check if paypal request or response
if (!isset($_POST["txn_id"]) && !isset($_POST["txn_type"])){
// Firstly Append paypal account to querystring
$querystring .= "?business=".urlencode($paypal_email)."&";
// Append amount& currency (£) to quersytring so it cannot be edited in html
//The item name and amount can be brought in dynamically by querying the $_POST['item_number'] variable.
$querystring .= "item_name=".urlencode($item_name)."&";
$querystring .= "amount=".urlencode($item_amount)."&";
//loop for posted values and append to querystring
foreach($_POST as $key => $value){
$value = urlencode(stripslashes($value));
$querystring .= "$key=$value&";
}
// Append paypal return addresses
$querystring .= "return=".urlencode(stripslashes($return_url))."&";
$querystring .= "cancel_return=".urlencode(stripslashes($cancel_url))."&";
$querystring .= "notify_url=".urlencode($notify_url);
// Append querystring with custom field
//$querystring .= "&custom=".USERID;
// Redirect to paypal IPN
header('location:https://www.sandbox.paypal.com/cgi-bin/webscr'.$querystring);
exit();
}else{
// Response from Paypal
// read the post from PayPal system and add 'cmd'
$req = 'cmd=_notify-validate';
foreach ($_POST as $key => $value) {
$value = urlencode(stripslashes($value));
$value = preg_replace('/(.*[^%^0^D])(%0A)(.*)/i','${1}%0D%0A${3}',$value);// IPN fix
$req .= "&$key=$value";
}
// assign posted variables to local variables
$data['item_name'] = $_POST['item_name'];
$data['item_number'] = $_POST['item_number'];
$data['payment_status'] = $_POST['payment_status'];
$data['payment_amount'] = $_POST['mc_gross'];
$data['payment_currency'] = $_POST['mc_currency'];
$data['txn_id'] = $_POST['txn_id'];
$data['receiver_email'] = $_POST['receiver_email'];
$data['payer_email'] = $_POST['payer_email'];
$data['custom'] = $_POST['custom'];
// 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";
$fp = fsockopen ('ssl://www.sandbox.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) {
// Used for debugging
//@mail("you@youremail.com", "PAYPAL DEBUGGING", "Verified Response<br />data = <pre>".print_r($post, true)."</pre>");
// Validate payment (Check unique txnid & correct price)
$valid_txnid = check_txnid($data['txn_id']);
$valid_price = check_price($data['payment_amount'], $data['item_number']);
// PAYMENT VALIDATED & VERIFIED!
if($valid_txnid && $valid_price){
$orderid = updatePayments($data);
if($orderid){
// Payment has been made & successfully inserted into the Database
}else{
// Error inserting into DB
// E-mail admin or alert user
}
}else{
// Payment made but data has been changed
// E-mail admin or alert user
}
}else if (strcmp ($res, "INVALID") == 0) {
// PAYMENT INVALID & INVESTIGATE MANUALY!
// E-mail admin or alert user
// Used for debugging
//@mail("you@youremail.com", "PAYPAL DEBUGGING", "Invalid Response<br />data = <pre>".print_r($post, true)."</pre>");
}
}
fclose ($fp);
}
}
?>
更新:这是 function.php.. 我希望这有助于有人帮我解决这个问题!
<?php
// functions.php
function check_txnid($tnxid){
global $link;
return true;
$valid_txnid = true;
//get result set
$sql = mysql_query("SELECT * FROM payments WHERE txnid = '$tnxid'", $link);
if($row = mysql_fetch_array($sql)) {
$valid_txnid = false;
}
return $valid_txnid;
}
function check_price($price, $id){
$valid_price = false;
//you could use the below to check whether the correct price has been paid for the product
/*
$sql = mysql_query("SELECT amount FROM `products` WHERE id = '$id'");
if (mysql_numrows($sql) != 0) {
while ($row = mysql_fetch_array($sql)) {
$num = (float)$row['amount'];
if($num == $price){
$valid_price = true;
}
}
}
return $valid_price;
*/
return true;
}
function updatePayments($data){
global $link;
if(is_array($data)){
$sql = mysql_query("INSERT INTO payments (txnid, payment_amount, payment_status, itemid, createdtime) VALUES (
'".$data['txn_id']."' ,
'".$data['payment_amount']."' ,
'".$data['payment_status']."' ,
'".$data['item_number']."' ,
'".date("Y-m-d H:i:s")."'
)", $link);
return mysql_insert_id($link);
}
}
?>
最佳答案
看起来您的工作有点“盲目”,因为这是一个“ headless ”脚本,您不知道它哪里出了问题。
在不同点添加一些 error_log 行,以便您可以检查脚本的流程。特别是,在执行数据库查询之前添加 error_log($sql) 会将语句打印到错误日志中。拿着这个并尝试在数据库中独立运行它。可能是某些表约束失败了,而不是 PHP 中的错误
在流程中的不同点添加日志行并在这些点打印出变量也将帮助您诊断发生故障的位置,并希望让您更准确地查明错误。
关于php - paypal IPN 不向 mysql 添加数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14785916/
我在尝试使用 PayPal 的 IPN 模拟器时得到这个答案(“很抱歉,我们无法发送 IPN”)。 我知道我可能会以各种方式做错事,但我想我现在已经涵盖了所有这些方式。当我自己发送带有虚拟事务数据的
在 PayPal(沙盒)中,我定义了一个日语用户,名字和姓氏都带有日语字符。 但是,我收到的 IPN 通知是用 charset=windows-1252 编码的。事实上,这是从 Paypal 收到的
在 PayPal(沙盒)中,我定义了一个日语用户,名字和姓氏都带有日语字符。 但是,我收到的 IPN 通知是用 charset=windows-1252 编码的。事实上,这是从 Paypal 收到的
我已将 PayPal 集成到我的网站中,并使 IPN 系统成功运行。我现在遇到的问题是,除非 PayPal 电子邮件与他们在我网站上注册时使用的电子邮件相同,否则我不知道这个人是谁。 我想将自己的数据
我正在尝试在网站上使用 Paypal IPN。 付款有效并标记为“已完成”。 返回网址有效。 发送一封电子邮件通知付款已完成 但是 paypal 似乎不与 IPN 脚本对话。用 Wireshark 检
我正在使用 Micah Carrick 的 PHP Paypal IPN 集成类并且在 paypal.class.php 中有如下代码: function __construct() {
根据这个paypal document在我们使用 IPN 将消息发送回 Paypal 之后,我们返回:- 如果消息有效,PayPal 将发送一个单字消息,VERIFIED;否则,它将发送另一个单字消息
我遇到了 paypal IPN 的问题,当我使用 paypal 立即购买按钮时它总是无效,但是它与 IPN 模拟器完美配合。 我知道在 stackoverflow 上有很多关于此的问题和答案可以提供帮
我在使用“旧”PayPal IPN 代码时遇到问题。当我使用 PayPal IPN 模拟器时,我收到消息 IPN was sent and the handshake was verified. 但在
我刚刚将我的服务器移动到一个新主机,显然更改了我的 paypal ipn 页面的 DNS。 出于某种原因,paypal 大约每 30 秒一次又一次地访问我的页面,并进行相同的交易。 当然,它经过验证,
如果我从这里发送 IPN https://developer.paypal.com/developer/ipnSimulator/它工作正常。 如果我使用 PayPal 沙盒帐户和 PayPal 标准
我的 IPN URL 是 http://:85/它有一个自定义端口。这个 url 工作正常,但 paypal 总是在它的模拟器上给我错误,而不是在付款时调用我的 IPN。 什么会导致这个问题? 最佳答
如何在本地机器上使用即时支付通知模拟器? IPN 处理程序 URL 中将提供什么?我无法访问我们的路由器。 谢谢 最佳答案 您不能在本地主机上测试 IPN,因为 IPN 是关于 PayPal 服务器向
我有一个网站,其中使用 IPN 内置了一个简单的售票处。在过去的一个月里它一直在工作,我没有管它。我在同一个虚拟主机上的另一个支付网站上工作,这是我第一次指定“notification_url”。我注
我已经设置了订阅模块,但不确定 PayPal 发回我的 ipn.php 文件的内容。 想象一下: 我的网站 -> PayPal 支付(订阅) -> 支付成功 -> 流程 -> ipn.php ipn.
我已经在开发人员中设置了测试帐户 Business 和 Personal 以试用沙盒模式。 我在我的网站上设置了付款按钮。我单击按钮并转到 Paypal 。测试用户个人账户用于支付。当我查看 Payp
更新:(2/29/12) 好的,所以我在完全不同的服务器和托管公司上为不同的客户端再次遇到了同样的问题。 同样,只有 mail() 的脚本才能正确发送电子邮件,没有任何问题。然后我添加了与下面的代码类
我正在我的项目中实现 ipnlistner。我在我的 Paypal 帐户中设置了 ipn url。但我没有收到对该 url 的所有事务 ipn 响应。但是当我在我的帐户中检查 ipn 历史记录时,它显
我在 Paypal 沙盒环境中有“卖家账户”,我配置了用于监听来自 Paypal API 的 IPN 消息的 URL。我的 Web 服务器使用带有端口转发的动态 DNS。但是我在付款时无法从 Payp
我在用 Java 编写 IPN 接收器时想知道这个问题,它将用于自动处理 IPN,因为实际的软件是在 Java 中运行的。 IPN 处理器是我项目中的一个类,用于加快处理速度,避免在中间使用 PHP。
我是一名优秀的程序员,十分优秀!