Binance.Spot
1.5.0
See the version list below for details.
dotnet add package Binance.Spot --version 1.5.0
NuGet\Install-Package Binance.Spot -Version 1.5.0
<PackageReference Include="Binance.Spot" Version="1.5.0" />
paket add Binance.Spot --version 1.5.0
#r "nuget: Binance.Spot, 1.5.0"
// Install Binance.Spot as a Cake Addin #addin nuget:?package=Binance.Spot&version=1.5.0 // Install Binance.Spot as a Cake Tool #tool nuget:?package=Binance.Spot&version=1.5.0
Binance Public API Connector DotNET
This is a lightweight library that works as a connector to Binance public API
- Supported APIs:
/api/*
/sapi/*
- Spot Websocket Market Stream
- Spot User Data Stream
- Test cases and examples
- Customizable base URL, request timeout and HTTP proxy
- Response Metadata
Installation
dotnet add package Binance.Spot
RESTful APIs
Usage example
using System;
using System.Threading.Tasks;
using Binance.Spot;
class Program
{
static async Task Main(string[] args)
{
Wallet wallet = new Wallet();
string status = await wallet.SystemStatus();
Console.WriteLine(status);
}
}
Please find more examples folder to check for more endpoints.
Websocket
using System;
using System.Threading;
using System.Threading.Tasks;
using Binance.Spot;
class Program
{
static async Task Main(string[] args)
{
var websocket = new MarketDataWebSocket("btcusdt@aggTrade");
websocket.OnMessageReceived(
(data) =>
{
Console.WriteLine(data);
return Task.CompletedTask;
}, CancellationToken.None);
await websocket.ConnectAsync(CancellationToken.None);
}
}
More websocket examples are available in the Examples
folder
Heartbeat
Once connected, the websocket server sends a ping frame every 3 minutes and requires a response pong frame back within a 10 minutes period. This package handles the pong responses automatically.
Testnet
While /sapi/*
endpoints don't have testnet environment yet, /api/*
endpoints can be tested in
Spot Testnet.
using Binance.Spot;
Wallet wallet = new Wallet(baseUrl: "https://testnet.binance.vision");
Base URL
If baseUrl
is not provided, it defaults to https://api.binance.com
.
It's recommended to pass in the baseUrl
parameter, even in production as Binance provides alternative URLs
in case of performance issues:
https://api1.binance.com
https://api2.binance.com
https://api3.binance.com
RecvWindow parameter
Additional parameter recvWindow
is available for endpoints requiring signature.
It defaults to 5000
(milliseconds) and can be any value lower than 60000
(milliseconds).
Anything beyond the limit will result in an error response from Binance server.
using Binance.Spot;
Wallet wallet = new Wallet();
await wallet.AccountStatus(recvWindow=4000)
Timeout
The default timeout is 100,000 milliseconds (100 seconds).
Usage Example
using System;
using System.Net.Http;
using Binance.Spot;
HttpClient httpClient = new HttpClient() {
Timeout = TimeSpan.FromSeconds(10)
}
Wallet wallet = new Wallet(httpClient: httpClient);
Proxy
Usage Example
using System;
using System.Net;
using System.Net.Http;
using Binance.Spot;
WebProxy proxy = new WebProxy(new Uri("http://1.2.3.4:8080"));
HttpClientHandler proxyHandler = new HttpClientHandler { Proxy = proxy };
HttpClient httpClient = new HttpClient(handler: proxyHandler);
Wallet wallet = new Wallet(httpClient: httpClient);
Exceptions
There are 2 types of exceptions returned from the library:
Binance.Common.BinanceClientException
- This is thrown when server returns
4XX
, it's an issue from client side. - Properties:
Code
- Server's error code, e.g.-1102
Message
- Server's error message, e.g.Unknown order sent.
- This is thrown when server returns
Binance.Common.BinanceServerException
- This is thrown when server returns
5XX
, it's an issue from server side.
- This is thrown when server returns
Both exceptions inherit Binance.Common.BinanceHttpException
along with the following properties:
StatusCode
- Response http status code, e.g.401
Headers
- Dictionary with response headers
Logging
This library implements the .NET logging API that works with a variety of built-in and third-party logging providers.
For more information on how to configure logging in .NET, visit Microsoft's logging article
Usage Example
using System;
using System.Net;
using System.Net.Http;
using Binance.Spot;
public async Task LoggingExample(ILogger logger) {
BinanceLoggingHandler loggingHandler = new BinanceLoggingHandler(logger: logger);
HttpClient httpClient = new HttpClient(handler: loggingHandler);
Wallet wallet = new Wallet(httpClient: httpClient);
await wallet.SystemStatus();
}
Sample Output
Method: GET, RequestUri: 'https://www.binance.com/?timestamp=1631525776809&signature=f07558c98cb82bcb3556a6a21b8a8a2582bae93d0bb9604a0df72cae8c1c6642', Version: 1.1, Content: <null>, Headers: { }
StatusCode: 200, ReasonPhrase: 'OK', Version: 1.1, Content: <null>, Headers: {}
{"status": 0,"msg": "normal"}
Test Cases
dotnet test
Limitations
Futures and Vanilla Options APIs are not supported:
- /fapi/*
- /dapi/*
- /vapi/*
- Associated Websocket Market and User Data Streams
Contributing
Contributions are welcome.
If you've found a bug within this project, please open an issue to discuss what you would like to change.
If it's an issue with the API, please open a topic at Binance Developer Community
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Newtonsoft.Json (>= 13.0.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Binance.Spot:
Package | Downloads |
---|---|
binance-connector-futures
connector to binance.com api |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
4.1.0 | 3,415 | 6/18/2024 |
4.0.1 | 13,423 | 10/4/2023 |
4.0.0 | 4,272 | 6/28/2023 |
4.0.0-rc1 | 473 | 4/27/2023 |
3.0.0 | 4,584 | 3/29/2023 |
2.0.0 | 5,404 | 11/22/2022 |
1.8.0 | 8,341 | 8/12/2022 |
1.7.0 | 964 | 7/19/2022 |
1.6.0 | 2,386 | 7/4/2022 |
1.5.0 | 1,383 | 5/27/2022 |
1.4.0 | 3,859 | 4/20/2022 |
1.3.1 | 2,540 | 3/8/2022 |
1.3.0 | 772 | 3/2/2022 |
1.2.0 | 846 | 2/16/2022 |
1.1.0 | 980 | 1/19/2022 |
1.0.0 | 715 | 12/2/2021 |