PHP Extension Stripe: Create a Bank Account Token

Back to Index

Creates a single use token that wraps the details of a bank account. This token can be used in place of a bank account dictionary with any API method.

Documentation: https://stripe.com/docs/api/curl#create_bank_account_token

CURL Command

curl https://api.stripe.com/v1/tokens \
   -u STRIPE_SECRET_KEY: \
   -d bank_account[country]=US \
   -d bank_account[currency]=usd \
   -d bank_account[account_holder_name]="Chloe White" \
   -d bank_account[account_holder_type]=individual \
   -d bank_account[routing_number]=110000000 \
   -d bank_account[account_number]=000123456789 \
   -X POST

PHP Extension Example

<?php

// The version number (9_5_0) should match version of the Chilkat extension used, omitting the micro-version number.
// For example, if using Chilkat v9.5.0.48, then include as shown here:
include("chilkat_9_5_0.php");

$rest = new CkRest();

//  URL: https://api.stripe.com/v1/tokens
$bTls = true;
$port = 443;
$bAutoReconnect = true;
$success = $rest->Connect('api.stripe.com',$port,$bTls,$bAutoReconnect);
if ($success != true) {
    print 'ConnectFailReason: ' . $rest->get_ConnectFailReason() . "\n";
    print $rest->lastErrorText() . "\n";
    exit;
}

$rest->SetAuthBasic('STRIPE_SECRET_KEY','');

$rest->AddQueryParam('bank_account[country]','US');
$rest->AddQueryParam('bank_account[currency]','usd');
$rest->AddQueryParam('bank_account[account_holder_name]','Chloe White');
$rest->AddQueryParam('bank_account[account_holder_type]','individual');
$rest->AddQueryParam('bank_account[routing_number]','110000000');
$rest->AddQueryParam('bank_account[account_number]','000123456789');

$strResponseBody = $rest->fullRequestFormUrlEncoded('POST','/v1/tokens');
if ($rest->get_LastMethodSuccess() != true) {
    print $rest->lastErrorText() . "\n";
    exit;
}

$jsonResponse = new CkJsonObject();
$jsonResponse->Load($strResponseBody);

$id = $jsonResponse->stringOf('id');
$object = $jsonResponse->stringOf('object');
$bank_accountId = $jsonResponse->stringOf('bank_account.id');
$bank_accountObject = $jsonResponse->stringOf('bank_account.object');
$bank_accountAccount_holder_name = $jsonResponse->stringOf('bank_account.account_holder_name');
$bank_accountAccount_holder_type = $jsonResponse->stringOf('bank_account.account_holder_type');
$bank_accountBank_name = $jsonResponse->stringOf('bank_account.bank_name');
$bank_accountCountry = $jsonResponse->stringOf('bank_account.country');
$bank_accountCurrency = $jsonResponse->stringOf('bank_account.currency');
$bank_accountFingerprint = $jsonResponse->stringOf('bank_account.fingerprint');
$bank_accountLast4 = $jsonResponse->stringOf('bank_account.last4');
$bank_accountRouting_number = $jsonResponse->stringOf('bank_account.routing_number');
$bank_accountStatus = $jsonResponse->stringOf('bank_account.status');
$client_ip = $jsonResponse->IsNullOf('client_ip');
$created = $jsonResponse->IntOf('created');
$livemode = $jsonResponse->BoolOf('livemode');
$type = $jsonResponse->stringOf('type');
$used = $jsonResponse->BoolOf('used');

?>

Sample JSON Response Body

{
  "id": "btok_1BnETKGswQrCoh0X86abg4gM",
  "object": "token",
  "bank_account": {
    "id": "ba_1BnETKGswQrCoh0XptCSwzal",
    "object": "bank_account",
    "account_holder_name": "Jane Austen",
    "account_holder_type": "individual",
    "bank_name": "STRIPE TEST BANK",
    "country": "US",
    "currency": "usd",
    "fingerprint": "L2j4aSuWk1MZMDZ5",
    "last4": "6789",
    "routing_number": "110000000",
    "status": "new"
  },
  "client_ip": null,
  "created": 1516662782,
  "livemode": false,
  "type": "bank_account",
  "used": false
}