Я разрабатываю веб-приложение, которое использует платежный шлюз. Мне нужно взимать 5 долларов за каждую транзакцию с моей страйп-учетной записи, а остальные переводить на страйп-аккаунт поставщика.
Я сделал следующие шаги.
1). для подключения пользователей я поделился этим URL
https://connect.stripe.com/oauth/authorize?response_type=code&client_id=ca_5slZHMozXs9B7rrgh6MDIFcdTvYqSdfz&scope=read_write
2). Настройте URL-адрес перенаправления для моего приложения и выполните следующие коды для обработки запроса.
if (isset($_GET['code'])) { // Redirect w/ code
$code = $_GET['code'];
$token_request_body = array(
'grant_type' => 'authorization_code',
'client_id' => 'ca_5slZHMozXs9B7rrgh6MDIFcdTvYqSdfz',
'code' => $code,
'client_secret' => 'sk_test_WcXfM3Tsb0IlkSKmbZTYnq5d'
);
$req = curl_init("https://connect.stripe.com/oauth/token");
curl_setopt($req, CURLOPT_RETURNTRANSFER, true);
curl_setopt($req, CURLOPT_POST, true );
curl_setopt($req, CURLOPT_POSTFIELDS, http_build_query($token_request_body));
curl_setopt($req, CURLOPT_SSL_VERIFYPEER, FALSE);
//curl_setopt($req, CURLOPT_CAINFO, "assets/cacert.pem");
// TODO: Additional error handling
$respCode = curl_getinfo($req, CURLINFO_HTTP_CODE);
$resp = json_decode(curl_exec($req), true);
curl_close($req);
echo $resp['access_token'];
echo "<br/>";
echo $resp['stripe_publishable_key'];
echo "<br/>";
echo $resp['stripe_user_id'];
} else if (isset($_GET['error'])) { // Error
echo $_GET['error_description'];
} else { // Show OAuth link
$authorize_request_body = array(
'response_type' => 'code',
'scope' => 'read_write',
'client_id' => 'ca_5slZHMozXs9B7rrgh6MDIFcdTvYqSdfz'
);
$url = AUTHORIZE_URI . '?' . http_build_query($authorize_request_body);
echo "<a href='$url'>Connect with Stripe</a>";
}
Я получил следующий ответ
sk_test_iLSNjRezyNiOiRpQk83UwQ6q
pk_test_0WXzhiA6xehlaZnmPZqP5VBi
acct_15iIu1I4jMsDTdhX
2). Затем я использовал следующий код в html-файле, чтобы получить данные кредитной карты. Поместите публикуемый ключ, как указано выше, вернул публикуемый ключ.
<script src="https://checkout.stripe.com/v2/checkout.js" class="stripe-button"
data-key="pk_test_0WXzhiA6xehlaZnmPZqP5VBi"
data-email= "<?php echo $usremail; ?>"
data-amount="<?php echo $valCoursefee*100; ?>" data-description="Pay & Enroll">
</script>
3). Затем я сделал следующее кодирование для получения токена и оплаты с карты. Используемый выше возвращал stripe_user_id для параметра Stripe-Account.
// Get the credit card details submitted by the form
$token = $_POST['stripeToken'];
// Stripe_Stripe::setApiKey("sk_test_WcXfM3Tsb0IlkSKmbZTYnq5d");
// Create the charge on Stripe's servers - this will charge the user's card
$charge = Stripe_Charge::create(
array(
"amount" => 1000, // amount in cents
"currency" => "usd",
"source" => $token,
"description" => "[email protected]",
"application_fee" => 5 // amount in cents
),
array("Stripe-Account" => "acct_15iIu1I4jMsDTdhX")
);
Но он возвращает мне следующую ошибку
Fatal error: Uncaught exception 'Stripe_InvalidRequestError' with message 'There is no token with ID tok_15lW5jI4jMsDTdhXhG9vfnjk.' in C:\wamp2\www\NEW\application\libraries\payment_gateway\lib\Stripe\ApiRequestor.php on line 147
Не могли бы вы посоветовать мне, если я делаю что-то неправильно здесь