Авторизация braintree Подтвердите и сохраните кредитную карту php - PullRequest
0 голосов
/ 14 марта 2019

Я строю электронную коммерцию на 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>";
}

}
?>

Ответы [ 2 ]

4 голосов
/ 14 марта 2019

Полное раскрытие: я работаю в Braintree. Если у вас есть дополнительные вопросы, не стесняйтесь обращаться поддержка .

Самое простое решение, которое вы пытаетесь сделать, - это передать параметр storeInVault в ваш вызов Transaction::sale(). Это сохраняет информацию о клиенте в вашем хранилище до тех пор, пока платеж будет успешным.

Кроме того, вы можете создать клиента, интегрировав наш вызов Customer::create() в свой код с параметром verifyCard.

1 голос
/ 14 марта 2019

Я рекомендую следовать официальному руководству по адресу https://developers.braintreepayments.com/guides/transactions/php

Способ сбора данных кредитной карты (например, номер или срок действия) не соответствует требованиям, налагаемым Braintree, и может привести к приостановке или прекращениюВаш аккаунт.

Данные кредитной карты не должны быть доступны вашему серверу.Вам лучше использовать Drop-in UI или Hosted fields .

...