Braintree授权验证和存储信用卡PHP



i在PHP中构建电子商务,此页面应授权信用卡。如果有效,我将将其存储在客户页面上。

我为此编写了此代码,但我仍然没有得到如何授权卡不收费。

代码

<?php
if($_SERVER["REQUEST_METHOD"] == "POST" && !empty($_POST['card_number']) && !empty($_POST['card_name']) && !empty($_POST['expiry_month']) && !empty($_POST['expiry_year']) && !empty($_POST['cvv']))
{
$card_number=str_replace("+","",$_POST['card_number']);  
$card_name=$_POST['card_number'];
$expiry_month=$_POST['expiry_month'];
$expiry_year=$_POST['expiry_year'];
$cvv=$_POST['cvv'];
$expirationDate=$expiry_month.'/'.$expiry_year;
require_once 'braintree/Braintree.php';
Braintree_Configuration::environment('production'); /* this is sandbox or production */
Braintree_Configuration::merchantId('id');
Braintree_Configuration::publicKey('public');
Braintree_Configuration::privateKey('secrit ');
$result = Braintree_Transaction::sale(array(
'amount' => 0,
'creditCard' => array(
'number' => $card_number,
'cardholderName' => $card_name,
'expirationDate' => $expirationDate,
'cvv' => $cvv
)
));
//echo "<pre>";
echo $result->message;
die;
if ($result->success) 
{
    //print_r("success!: " . $result->transaction->id);
    if($result->transaction->id)
    {
        $braintreeCode=$result->transaction->id;
        echo "<h2>Your payment successfully done ".$braintreeCode."</h2>";
    }
}else if ($result->transaction){
        echo "<pre>";
        print_r($result->transaction);
        //echo '{"OrderStatus": [{"status":"2"}]}';
}else{
    echo "<h2>Your payment is not completed</h2>";
}
}
?>

全面披露:我在Braintree工作。如果您还有其他问题,请随时联系支持。

最简单的修复方法是将storeInVault参数传递到Transaction::sale()调用中。只要付款成功,这就会将客户信息保存到您的保险库中。

此外,您可以通过将我们的Customer::create()调用与verifyCard参数集成到代码中来创建客户。

我建议遵循https://developers.braintreepayments.com/guides/guides/transactions/php

的官方指南

您收集信用卡数据的方式(例如号码或到期日)不符合Braintree的要求,并可能导致您的帐户中止或终止。

信用卡数据不适用于您的服务器。您应该宁愿使用Drop-In UI或托管字段。

最新更新