The purpose of this project is to assist you in creating your own projects that interact with the Binance SPOT API.
Supported in the current version Wallet Endpoints, Market Data Endpoints and Spot Account/Trade
This project requires php version more or equal 8.2. Also it requires bcmath extension and guzzle dependency
composer require kleninm/binance-api
Every original method's name in \BinanceApi\Binance
class created by name from url after prefix v1
, v2
or v3
.
For example, by table:
Link to endpoint | Method name |
$binance->depth($symbol, $limit); | |
$binance->tickerBookTicker($symbol); | |
$binance->ticker24hr($symbol, $symbols, $type); | |
$binance->capitalWithdrawHistory(); |
All endpoints and their methods with parameters you can see in phpdoc in \BinanceApi\Binance
class
Full docs you can find in documentation
folder of this repository
Look at the Basic topic to learn more features
Look at the Digging deeper topic if you want to dive deep into the mechanism and add more yourself customizations and scale functionality
You can go to the Examples and Analogs topic to see more examples, include what each function returns
$binance = new \BinanceApi\Binance();
$fullResult = $binance->depth('BTCUSDT', 2);
$orderbook = $fullResult['response']['data'];
View $fullResult variable
Array
(
[request] => Array
(
[url] => /api/v3/depth
[headers] => Array
(
)
[query] => Array
(
[symbol] => BTCUSDT
[limit] => 2
)
[body] => Array
(
)
)
[response] => Array
(
[data] => Array
(
[lastUpdateId] => 37910427874
[bids] => Array
(
[0] => Array
(
[price] => 30319.99000000
[amount] => 3.58155000
)
[1] => Array
(
[price] => 30319.98000000
[amount] => 0.09091000
)
)
[asks] => Array
(
[0] => Array
(
[price] => 30320.00000000
[amount] => 21.24342000
)
[1] => Array
(
[price] => 30320.05000000
[amount] => 0.00170000
)
)
)
[info] => Array
(
[statusCode] => 200
[reasonPhrase] => OK
[headers] => Array
(
[Content-Type] => Array
(
[0] => application/json;charset=UTF-8
)
...
[x-mbx-uuid] => Array
(
[0] => ad6df6c5-903b-451b-904c-5ba90eb4576d
)
[x-mbx-used-weight] => Array
(
[0] => 1
)
[x-mbx-used-weight-1m] => Array
(
[0] => 1
)
...
)
)
)
)
If you want to use testnet
$binanceTestNet = new \BinanceApi\Binance(TestNet::BASE_ENDPOINT);
$fullResult = $binance->depth('BTCUSDT', 2);
Some endpoints will require an API Keys. You can set them like this:
$binance->setApiKeys($apiKey, $secretKey);
try {
$result = $binance->depth('BTCUSDT', 2);
} catch (BinanceApi\Exception\BinanceResponseException $e) {
// This is exception throw, when binance return error message
// https://binance-docs.github.io/apidocs/spot/en/#error-codes
} catch (\GuzzleHttp\Exception\GuzzleException $e) {
// It's about Guzzle exception
// https://docs.guzzlephp.org/en/stable/quickstart.html#exceptions
}
Full list of errors, you can see in Basic topic
Limits by IP
$binance->getAdditional()['limits']['IP']['api'];
Array
(
[used] => 2 // By default maximum weight in minute is 1200
[lastRequest] => Sat, 15 Jul 2023 14:19:01 GMT
)
$dateTime = new DateTime($binance->getAdditional()['limits']['IP']['api']['lastRequest']);
$dateTime = new DateTime($binance->getAdditional()['limits']['IP']['sapi']['lastRequest']);
You know how much weight you use
Binance reset weights by IP (api and sapi) every minute
At any places where you need to use time, use a binance microtime format
You can get binance microtime now by function:
\BinanceApi\Docs\GeneralInfo\Signed::binanceMicrotime(); //1690113560956
Common part for all next examples
$binance = new \BinanceApi\Binance();
$binance->setApiKeys($apiKey, $secretKey);
// Filter every output. Read more about it in a Basic topic or just use it if you need only a body result from request
$binance->setOutputCallback(function ($output) {
return $output['response']['data'];
});
Current exchange trading rules and symbol information
$binance->exchangeInfo();
All three methods are identical. Use that you prefer
$binance->depth('BTCUSDT', 5);
$binance->orderbook('BTCUSDT', 5);
$binance->orderbookBTCUSDT(5); // "BTCUSDT" you can replace with any market: "ETHUSDT", "BTCBUSD", ...
All two methods are identical. Use that you prefer
$binance->trades('BTCUSDT', 5);
$binance->tradesETHUSDT(5); // "ETHUSDT" you can replace with any market: "BTCUSDT", "BTCBUSD", ...
Kline/candlestick bars for a symbol.
$binance->klines('BTCUSDT', '1m', limit: 50);
$startTime = (new DateTime('01 Jan 2022 00:00:00 GMT'))->getTimestamp() * 1000;
$binance->klines('BTCUSDT', '1d', $startTime);
$endTime = (new DateTime('01 Jan 2023 00:00:00 GMT'))->getTimestamp() * 1000;
$binance->klines('BTCUSDT', '1d', endTime: $endTime);
$binance->secondKlines('BTCUSDT');
$binance->minuteKlines('BTCUSDT');
$binance->threeMinuteKlines('BTCUSDT');
$binance->fiveMinuteKlines('BTCUSDT');
$binance->fifteenMinuteKlines('BTCUSDT');
$binance->thirtyMinuteKlines('BTCUSDT');
$binance->hourKlines('BTCUSDT');
$binance->twoHourKlines('BTCUSDT');
$binance->fourHourKlines('BTCUSDT');
$binance->sixHourKlines('BTCUSDT');
$binance->eightHourKlines('BTCUSDT');
$binance->twelveHourKlines('BTCUSDT');
$binance->dayKlines('BTCUSDT');
$binance->threeDayKlines('BTCUSDT');
$binance->weekKlines('BTCUSDT');
$binance->monthKlines('BTCUSDT');
$startTime = new DateTime('01 Jan 2022 00:00:00 GMT');
$binance->hourKlines('BTCUSDT', $startTime, limit: 24);
$endTime = new DateTime('01 Jan 2022 00:00:00 GMT');
$binance->hourKlines('BTCUSDT', endTime: $endTime, limit: 48);
Latest price for a symbol or symbols.
$binance->tickerPrice();
$binance->tickerPrice('BTCUSDT');
$binance->order('BTCUSDT', 'BUY', 'LIMIT', 'GTC', 0.01, price: 20000);
$binance->limitOrder('BTCUSDT', 'BUY', 0.01, price: 21000);
$binance->order('BTCUSDT', 'BUY', 'MARKET', quantity: 0.01);
$binance->marketOrder('BTCUSDT', 'SELL', 0.01);
$binance->order('BTCUSDT', 'SELL', 'STOP_LOSS', 'GTC', 0.01, stopPrice: 25000);
$binance->stopLossOrder('BTCUSDT', 'SELL', 0.01, stopPrice: 25000);
$binance->order('BTCUSDT', 'SELL', 'TAKE_PROFIT', 'GTC', 0.01, stopPrice: 100000);
$binance->takeProfitOrder('BTCUSDT', 'SELL', 0.01, stopPrice: 100000);
Get all open orders on a symbol. Careful when accessing this with no symbol.
$binance->openOrders('BTCUSDT');
$binance->openOrders();
Check an order's status.
$binance->getOrder('BTCUSDT', 8403075);
Cancel an active order.
$binance->cancelOrder('BTCUSDT', 8403075);
Cancels all active orders on a symbol.
$binance->cancelOpenOrders('BTCUSDT');
Get current account information.
$binance->account();
Get trades for a specific account and symbol.
$binance->myTrades('BTCUSDT');
Get information of coins (available for deposit and withdraw) for user.
$binance->capitalConfigGetall();
Submit a withdraw request.
$binance->capitalWithdrawApply('USDT', network: 'TRX', address: 'TNGjavWm7sMjCA4r1YhsEYGfaZtZEkXzNf', amount: 10);
$binance->withdraw('USDT', network: 'TRX', address: 'TNGjavWm7sMjCA4r1YhsEYGfaZtZEkXzNf', amount: 10);
Fetch withdraw history.
$binance->capitalWithdrawHistory();
Fetch deposit address with network.
$binance->capitalDepositAddress('USDT', 'TRX');
Fetch deposit history.
$binance->capitalDepositHisrec();
- Please give a star or fork repository 💫
- Create a new issues or pull requests 🤝
Binance PHP API Client is licensed under The MIT License (MIT).