Software Development

A Comprehensive Guide for Developing Real-Time Applications Using Flutter and WebSockets

admin
15 March 2024
A Comprehensive Guide for Developing Real-Time Applications Using Flutter and WebSockets

Overview

Have you ever thought about how important it is for modern applications to have real-time functionality and rapid mobile app development? Real-time capabilities are essential for many functions, such as live notifications, stock market rate synchronization, and messaging. If these needs are only met by REST, this means that the server may be overworked due to repeated requests to the same endpoint. Thankfully, there is a solution available in the form of Real-Time Apps With Flutter and WebSockets, which enable smooth bidirectional communication channels between the server and the client.

How do Web Sockets Work?

A communication protocol called websockets enables real-time, full-duplex communication via a single, persistent connection between a client and a server. A websocket allows both the client and the server to start the data transmission, unlike HTTP, which follows a request-response architecture. This creates a persistent connection that stays open until it is closed expressly. This provides a seamless real-time experience by enabling message sending between the client and the server at any moment.

What Uses Do WebSockets Serve?

The constant, full-duplex communication between the WebSocket server and client is started by WebSockets. As a result, less traffic is needed because data may move quickly in both directions over a single connection, giving the web speed and real-time functionality. Additionally, servers may monitor clients and send them data as needed via WebSockets, something that is not possible with HTTP alone. WebSockets are utilized in a number of situations where instantaneous communication is necessary, including:

  • Chat Applications
  • Multiplayer Online Games
  • Financial Trading Platforms
  • Live Sports Updates
  • Live Collaboration Tools
  • Real-time Monitoring And Tracking Systems

Flutter-Based WebSocket Support

WebSockets are heavily supported by Flutter through the WebSocketIO class. But it’s important to remember that this package depends on “dart.io” and “dart:html,” which means we can’t compile for both web and mobile applications at the same time. In order to address this problem, the Dart team developed the ‘web_socket_channel’ package, which assembles both libraries enabling seamless cross-platform development.

Configuring the project for Dart Server

Let’s begin by making a brand-new one. First, make sure the most recent version of the Dart SDK is installed. Launch a terminal window and type the following commands:

dart create -t server-shelf web_socket_server
cd web_socket_server

Setting up a WebSocket Server to Receive Requests for WebSocket IO

Let’s start by looking at the code of the Dart server, which is capable of actively listening for WebSocket IO requests made to it, ensuring that these requests are handled skillfully.

void main(List args) async {
 // Use any available host or container IP (usually `0.0.0.0`).
 var server = await HttpServer.bind(InternetAddress.anyIPv4, 8080);
 print('WebSocket server listening on ${server.address}:${server.port}');

 await for (var request in server) {
  //receive the websocket request
  WebSocketTransformer.upgrade(request).then(
   (webSocket) async {
    print('Client connected');
   },
  );
 }
}

Let’s now add some logic to send data to the connected client from our server. To be more precise, we will send the client prices for arbitrary bitcoin coins to track. We will be able to test our client connection in real-time because these costs will be updated every second.
Every time it is called, a specific function has been created to provide five different random prices, each ranging from 100 to 200.

List<map<string, dynamic="">> generateRandomPrices() {
 final List cryptocurrencies = [
  'Bitcoin',
  'Ethereum',
  'Ripple',
  'Litecoin',
  'Cardano'
 ];
 final Random random = Random();

 List<map<string, dynamic="">> prices = cryptocurrencies.map(
  (crypto) {
   // Random price between 100 and 200
   double price = 100.0 + random.nextDouble() * 100.0;
   return {
    'name': crypto,
    'symbol': crypto.substring(0, 3),
    'price': price.toStringAsFixed(2)
   };
  },
 ).toList();

 return prices;
}</map<string,></map<string,>

Next, implement the logic to handle the WebSocket request and send back the cryptocurrency coin prices.

WebSocketTransformer.upgrade(request).then(
   (webSocket) async {
    print('Client connected');
    // Fetch initial cryptocurrency prices with a delay of 3 seconds to show loading
    await Future.delayed(
     Duration(seconds: 3),
    );
    List<map<string, dynamic="">> initialPrices = generateRandomPrices();
    webSocket.add(
     jsonEncode(initialPrices),
    );
    // Set up a timer to update prices every second
    Timer.periodic(
     Duration(seconds: 1),
     (timer) {
      List<map<string, dynamic="">> updatedPrices =  generateRandomPrices();
      webSocket.add(
       jsonEncode(updatedPrices),
      );
     },
    );
    webSocket.listen(
     (data) {
      // You can add custom logic for handling client messages here
      print('Received data: $data');
     },
     onDone: () {
      print('Client disconnected');
     },
    );
   },
  );</map<string,></map<string,>

Additionally, in order to effectively control the loading behavior, we have added a 3-second wait to the initial request.

In your terminal, use the following command to launch the dart server project:

dart run bin/server.dart

Configuring the Flutter project

Installing the most recent Flutter SDK is essential before starting a new Flutter project. Open your terminal and run the following commands:

flutter create web_socket_client
cd web_socket_client

Including IO Dependencies for WebSocket

We need to incorporate the web_socket_channel package into our project in order to effectively use websockets in Dart. Open the “pubspec.yaml” file at your project’s root directory and add the following lines:

dependencies:
 web_socket_channel: ^2.4.0

Remember to use your terminal to perform `flutter pub get` in order to obtain and install the updated dependencies.

Linking up with a WebSocket

We will create a simple application that connects to a WebSocket channel now that the project setup is complete.

import 'package:flutter/material.dart';
import 'package:web_socket_channel/web_socket_channel.dart';

void main() => runApp(WebSocketApp());

class WebSocketApp extends StatelessWidget {
 final WebSocketChannel channel = WebSocketChannel.connect(
  Uri.parse('ws://192.168.3.243:8080'),
 );

 WebSocketApp({super.key});

 @override
 Widget build(BuildContext context) {
  return MaterialApp(
   home: Scaffold(
    appBar: AppBar(
     title: const Text('Crypto Tracker'),
    ),
    body: Container(),
   ),
  );

URLs for WebSockets usually start with “ws:” or “wss:”. We have successfully established a connection to a WebSocket and are now prepared to work with incoming data. However, have you thought about how this information will be updated and shown whenever fresh data is received from the server?

We will use Flutter’s integrated StreamBuilder widget to solve this. Every time new information is found in the data stream, this widget has the ability to refresh the data. Such a data stream is what WebSocket uses to provide bidirectional communication, which is essential for real-time applications.

Constructing a Real-Time Function

We are currently developing a StreamBuilder widget to receive data from our websocket and show it.

import 'dart:convert';
import 'dart:io';

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:web_socket_channel/web_socket_channel.dart';

void main() => runApp(WebSocketApp());

class WebSocketApp extends StatelessWidget {
 final WebSocketChannel channel = WebSocketChannel.connect(
  // here the url can be replaced with your own websocket url
  Uri.parse('ws://192.168.3.243:8080'),
 );

 WebSocketApp({super.key});

 @override
 Widget build(BuildContext context) {
  return MaterialApp(
   home: Scaffold(
    appBar: AppBar(
     title: const Text('Crypto Tracker'),
    ),
    body: StreamBuilder(
     stream: channel.stream,
     builder: (context, snapshot) {
      if (snapshot.hasData) {
       List body = jsonDecode(snapshot.data);
       return ListView.builder(
        shrinkWrap: true,
        itemCount: body.length,
        itemBuilder: (context, index) => ListTile(
         leading: Text(
          body[index]["symbol"],
         ),
         title: Text(
          body[index]["name"],
         ),
         trailing: Text(
          '₹${body[index]["price"]}',
         ),
        ),
       );
      } else if (snapshot.hasError) {
       return Center(
        child: Text(
         'Error Connecting : ${snapshot.error.toString()}',
        ),
       );
      } else {
       return Center(
        child: Platform.isIOS
          ? const CupertinoActivityIndicator()
          : const CircularProgressIndicator(),
       );
      }
     },
    ),
   ),
  );
 }
}

With the aid of the StreamBuilder widget, this straightforward application establishes a connection to a WebSocket and shows the data obtained from the server.

In summary

This suggests that creating real-time apps with WebSockets and Flutter is an effective way to create real-time functionalities. To fulfill the needs of modern consumers, your development team may create interactive, engaging experiences by providing bidirectional communication channels between clients and servers. With server-side Dart and Flutter’s strong websocket support, developers can create scalable, cross-platform real-time applications. For assistance in creating real-time app communication capabilities for your Flutter development project, get in touch with a Flutter app development company.

Table of Contents

Recent Comments
    January 2025
    M T W T F S S
     12345
    6789101112
    13141516171819
    20212223242526
    2728293031  
    Tags:
    androidiOSmobilemobile app development
    3 likes
    Leave a Comment
    Share:
    Social