Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual Basic 6.0) WebSocket Binance Trade Stream (subscribe and receive updates)Subscribe to a binance trade stream and receive updates. For more information, see https://binance-docs.github.io/apidocs/spot/en/#live-subscribing-unsubscribing-to-streams
' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. Dim ws As New ChilkatWebSocket ' For brevity, this example does not check for errors when etablishing the WebSocket connection. ' See Establish WebSocket Connection for more complete sample code for making the connection. Dim rest As New ChilkatRest ' Connect to wss://stream.binance.com:9443 Dim success As Long success = rest.Connect("stream.binance.com",9443,1,0) If (success = 0) Then Debug.Print rest.LastErrorText Exit Sub End If success = ws.UseConnection(rest) If (success = 0) Then Debug.Print ws.LastErrorText Exit Sub End If success = ws.AddClientHeaders() ' Raw streams are accessed at /ws/<streamName> Dim responseBody As String responseBody = rest.FullRequestNoBody("GET","/ws/btcusdt") If (rest.LastMethodSuccess = 0) Then Debug.Print rest.LastErrorText Exit Sub End If success = ws.ValidateServerHandshake() If (success <> 1) Then Debug.Print ws.LastErrorText Debug.Print responseBody Debug.Print rest.ResponseHeader Exit Sub End If Debug.Print responseBody Debug.Print rest.ResponseHeader ' POST JSON to subscribe to a stream ' { ' "method": "SUBSCRIBE", ' "params": ' [ ' "btcusdt@aggTrade", ' "btcusdt@depth" ' ], ' "id": 1 ' } Dim json As New ChilkatJsonObject success = json.UpdateString("method","SUBSCRIBE") success = json.UpdateString("params[0]","btcusdt@aggTrade") success = json.UpdateString("params[1]","btcusdt@depth") success = json.UpdateInt("id",1) ' Send a full message in a single frame Dim finalFrame As Long finalFrame = 1 success = ws.SendFrame(json.Emit(),finalFrame) If (success <> 1) Then Debug.Print ws.LastErrorText Exit Sub End If Dim jsonTradeData As New ChilkatJsonObject jsonTradeData.EmitCompact = 0 ' Begin reading the trade stream response. ' We'll just read the 1st 10 updates and then exit.. Dim receivedFinalFrame As Long receivedFinalFrame = 0 Dim numTradesReceived As Long numTradesReceived = 0 Do While numTradesReceived < 5 success = ws.ReadFrame() If (success <> 1) Then Debug.Print "Failed to receive a frame" Debug.Print "ReadFrame fail reason = " & ws.ReadFrameFailReason Debug.Print ws.LastErrorText Exit Sub End If ' The responses we desire are in Text frames, where the opcode = 1. If (ws.FrameOpcodeInt = 1) Then Dim receivedJson As String receivedJson = ws.GetFrameData() success = jsonTradeData.Load(receivedJson) Debug.Print jsonTradeData.Emit() numTradesReceived = numTradesReceived + 1 End If Loop ' Close the websocket connection. success = ws.SendClose(1,1000,"Closing this websocket.") If (success <> 1) Then Debug.Print ws.LastErrorText Exit Sub End If ' Read the Close response. success = ws.ReadFrame() If (success <> 1) Then Debug.Print "ReadFrame fail reason = " & ws.ReadFrameFailReason Debug.Print ws.LastErrorText Exit Sub End If Debug.Print "Success." ' The output of the above code is shown here: |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.