gpt4 book ai didi

php - 验证 POST 数据来自 PayPal

转载 作者:太空宇宙 更新时间:2023-11-03 16:30:37 26 4
gpt4 key购买 nike

如何验证 POST 数据来自 PayPal?

我在一家销售某些产品的商店工作。支付网关是 Paypal 。最初,我设置了一个自定义 PayPal 表单并使用 IPN 响应来验证从 PayPal 发送给我的数据。

现在我的客户已经购买了使用 PayPal PayFlow 的 PayPal Advance Payment。响应不再通过 IPN 发送(或者是吗?),而是通过 SILENT POST 返回,基本上,当在他们端执行事务时,它被发送到我选择的链接,我通过该链接处理数据。

如何验证 POST 数据的来源,以便我知道它来自 PayPal 而不是恶意用户。我找不到关于此的任何文档。当用户单击 Paypal 页面上的“取消”按钮并将其重定向到我网站上的取消页面时,我也希望有同样的想法。我希望 POST 数据源也得到验证。

对此有什么想法吗?

最佳答案

我找到的第一个解决方案,一些 PayPal 支持人员也提到了类似的东西,但他不能提供细节,因为他说他不是专家。

基本上,您必须使用从 SILENT POST 收到的 PNREF 运行 INQUIRY 类型的交易,如果响应返回等于 0 的 ORIGRESULT,则该交易存在于您帐户下的 PayPal 数据库中。

我还在查询中发送了 SECURE TOKEN ID 和 SECURE TOKEN,我不知道它是否有帮助,我在某个地方看到了这个解决方案,我尝试只发送没有 ORIGID 的 TOKEN 和 TOKEN ID,有时它有时有效不是。

在 PayPal 的开发者引用中指定在 TRXTYPE=I(INQUIRY TRANSACTION)上必须指定 ORIGID。

代码如下:

//GET POST DATA FROM SILENT POST
$data = $_POST;
$result = $data['RESULT'];
$pnref = $data['PNREF'];
$secure_token = $data['SECURETOKEN'];
$secure_token_id = $data['SECURETOKENID'];
$fee_amount = $data['AMT'];

if(!isset($result) || $result != '0'){
//DO TRANSACTION FAILED OPERATIONS
exit;
}

//CHECK IF PNREF ID EXISTS ON PAYPAL
$post_data = "PARTNER=yourpartnerid"
."&VENDOR=your_vendor"
."&USER=your_user"
."&PWD=your_password"
."&SECURETOKENID=" . $secure_token_id
."&SECURETOKEN=" . $secure_token
."&ORIGID=" . $pnref
."&TRXTYPE=I"
."&VERBOSITY=HIGH";


$ch = curl_init('https://payflowpro.paypal.com');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
curl_setopt($ch, CURLOPT_POST, TRUE);
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
$resp = curl_exec($ch);

$inquiry = array();
parse_str($resp, $inquiry);

//IF ORIGRESULT is 0 then PNREF/transaction exists.
if($inquiry['ORIGRESULT'] == '0' && $inquiry['RESPMSG'] == 'Approved'){ $validated = true; }
else{ $validated = false; }

if($result != 0 || $amount != 'your_correct_fee' || $validated == false){
// DO TRANSACTION NOT VALID OR HAS FAILED OPERATIONS
exit;
}

//DO TRANSACTION SUCCESSFULL OPERATIONS

INQUIRY 的响应看起来是这样的:

RESULT=0&PNREF=ETHPC0BBF5FB&TRANSSTATE=8&ORIGRESULT=0&ORIGPNREF=ELFPB0E766F5&RESPMSG=Approved&AVSADDR=N&AVSZIP=N&ORIGPPREF=8GT035513B296200N&CORRELATIONID=97306f6456378&SETTLE_DATE=2014-07-09 14:11:36&TRANSTIME=2014-07-09 14:11:36&FIRSTNAME=John&LASTNAME=doe&AMT=0.0

另一种方法是检查 SILENT POST 来自的 IP。我注意到所有 SILENT POST 数据都来自 173.0.81.65

$ip_address = $_SERVER['REMOTE_ADDR'];
if($ip_address != '173.0.81.65'){ exit; }

@安德鲁天使SILENT POST 和 NotifyURL 不是一回事。在 NotifyURL 中,您可以使用 IPN 和数据验证,因为您会收到不同类型的回邮数据字符串,所以那里的方式非常不同。

我与 PayPal 支持人员谈过,他们说 NotifyURL 和 IPN 不适用于 PayPal Advanced Payments,仅适用于 PayPal Payments Pro。

事实上,它们都执行相同的功能,但它们是不同的东西,源代码验证的方式也不同。

希望这对某人有帮助,等待意见。

关于php - 验证 POST 数据来自 PayPal,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24470445/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com