Ping 工具是一种简单而有效的网络工具,可以帮助用户测试网络连通性和性能,及时发现和解决网络问题。请在网路应用 Flutter 中开启这个功能~

Flutter Ping 检查服务器通讯信号强度

前言

对通讯敏感的程序中,我们除了检查当前网络通道外,还要检查与服务器实际的型号强度。

一般我们采用 ping 的方式返回型号的强度和稳定程度。

dart_ping 包

https://pub-web.flutter-io.cn/packages/dart_ping

ios dart_ping 包

https://pub-web.flutter-io.cn/packages/dart_ping_ios

ios 需要单独去设置

Ping 知识点

Ping 是一种常用的网络工具,用于测试网络设备之间的连通性和延迟。Ping 工具通过向目标设备发送一个 ICMP Echo Request 数据包,然后等待目标设备返回一个 ICMP Echo Reply 数据包,来检测目标设备的可达性和延迟。以下是关于 Ping 工具的一些重要信息:

作用:

  • 测试网络设备之间的连通性和延迟
  • 发现网络故障和嗅探网络拓扑结构
  • 验证网络性能和带宽

性能指标:

  • 延迟(Latency):指的是从发送一个数据包到接收到相应数据包所需的时间。
  • 丢包率(Packet Loss Rate):指的是在发送和接收数据包之间丢失的数据包的比例。
  • 带宽(Bandwidth):指的是网络中可用的数据传输速率,通常以比特/秒(bps)为单位。

如何判断:

  • 延迟:通常使用 Ping 工具的平均延迟来判断网络连接的延迟状况,如果延迟较高,可能会影响网络应用程序的性能。
  • 丢包率:如果 Ping 工具返回的丢包率较高,可能意味着网络连接不稳定,可能会影响网络应用程序的可靠性。
  • 带宽:如果 Ping 工具返回的延迟比较高,可能意味着网络瓶颈,可能会影响网络应用程序的带宽和性能。

步骤

第一步:导包,加入图片素材

pubspec.yaml

dart_ping 包

dependencies:
  flutter:
    sdk: flutter
    ...

  dart_ping: ^8.0.1

图片

  assets:
    - assets/images/

第二步:ping 业务实现

lib/ping.dart

成员变量

  // 检测域名
  final String _domain = 'baidu.com';
  // 信号量
  int _signalStrength = 0;
  // 返回信息
  String _resString = '';

ping 操作执行

  // 执行 ping
  void _doPing() {
    _resString = 'ping $_domain \n\n';
    final ping = Ping(_domain, count: 20);
    ping.stream.listen((event) {
      print(event);

      if (event.error != null) {
        // 错误
        setState(() {
          _resString = event.error.toString();
        });
      } else {
        if (event.response != null) {
          // 单次信息
          setState(() {
            _resString += '${event.response}\n';
          });

          // 信号强度
          _signalStrength = calculateSignalStrength(
              event.response?.time?.inMilliseconds ?? 0);
        }

        // 总计
        if (event.summary != null) {
          setState(() {
            _resString += '\n${event.summary}\n';
          });
        }
      }
    });
  }

信号强度

  // 信号强度 0 ~ 5 , 5 最好,0 最差
  int calculateSignalStrength(int pingDelay) {
    if (pingDelay < 0) {
      // 无网络连接
      return 0;
    } else if (pingDelay < 100) {
      // 延迟 < 100ms,信号强度为 5
      return 5;
    } else if (pingDelay < 200) {
      // 延迟 < 200ms,信号强度为 4
      return 4;
    } else if (pingDelay < 300) {
      // 延迟 < 300ms,信号强度为 3
      return 3;
    } else if (pingDelay < 500) {
      // 延迟 < 500ms,信号强度为 2
      return 2;
    } else {
      // 延迟 >= 500ms,信号强度为 1
      return 1;
    }
  }

视图

  Widget _mainView() {
    return Center(
      child: Column(
        children: [
          ElevatedButton(
            onPressed: _doPing,
            child: const Text('Start Ping'),
          ),
          Text('信号强度: $_signalStrength'),
          Text(_resString),
        ],
      ),
    );
  }
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Ping'),
      ),
      body: _mainView(),
    );
  }

第三步:用图片显示信号强度

信号图片

  // 信号强度图片
  Widget _buildSignalIcon(BuildContext context) {
    String iconAsset = 'assets/images/signal-$_signalStrength.png';
    return Image.asset(
      iconAsset,
      width: 28,
      height: 28,
      fit: BoxFit.fill,
    );
  }
  Widget _mainView() {
    return Center(
      child: Column(
        children: [
          ...
          _buildSignalIcon(context),
          ...
        ],
      ),
    );
  }

代码

https://github.com/ducafecat/flutter_develop_tips/tree/main/flutter_application_ping

小结

总之,Ping 工具是一种简单而有效的网络工具,可以帮助用户测试网络连通性和性能,及时发现和解决网络问题。请在网路应用 Flutter 中开启这个功能~

感谢阅读本文

如果我有什么错?请在评论中让我知道。我很乐意改进。


© 猫哥 ducafecat.com

end