flutter如何检测网络连接状态

在Flutter开发中,如何实时检测设备的网络连接状态?我现在需要在应用内监听网络变化,比如从WiFi切换到移动数据或断网时能及时获取状态。尝试过connectivity插件,但发现它只能检测网络类型变化,无法准确判断是否真正联网。有没有更可靠的方案?最好能兼容Android和iOS平台。

2 回复

使用connectivity_plus包检测网络连接状态。示例代码:

var connectivityResult = await Connectivity().checkConnectivity();
if (connectivityResult == ConnectivityResult.mobile) {
  // 移动网络
} else if (connectivityResult == ConnectivityResult.wifi) {
  // WiFi
} else {
  // 无网络
}

注意:仅检测网络可用性,不保证能访问互联网。

更多关于flutter如何检测网络连接状态的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


在Flutter中检测网络连接状态,可以使用 connectivity_plus 包。以下是实现步骤:

1. 添加依赖

pubspec.yaml 中添加:

dependencies:
  connectivity_plus: ^5.0.1

运行 flutter pub get 安装。

2. 基本使用

import 'package:connectivity_plus/connectivity_plus.dart';

// 检查当前连接状态
Future<void> checkConnectivity() async {
  final connectivityResult = await Connectivity().checkConnectivity();
  if (connectivityResult == ConnectivityResult.mobile) {
    print('移动网络');
  } else if (connectivityResult == ConnectivityResult.wifi) {
    print('WiFi');
  } else if (connectivityResult == ConnectivityResult.ethernet) {
    print('以太网');
  } else if (connectivityResult == ConnectivityResult.vpn) {
    print('VPN');
  } else if (connectivityResult == ConnectivityResult.bluetooth) {
    print('蓝牙');
  } else if (connectivityResult == ConnectivityResult.other) {
    print('其他网络');
  } else {
    print('无网络');
  }
}

3. 监听网络状态变化

StreamSubscription<ConnectivityResult>? subscription;

void listenNetwork() {
  subscription = Connectivity().onConnectivityChanged.listen((result) {
    // 处理网络状态变化
    print('网络状态变为: $result');
  });
}

// 记得在 dispose 时取消监听
@override
void dispose() {
  subscription?.cancel();
  super.dispose();
}

4. 完整示例

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

class NetworkStatusPage extends StatefulWidget {
  @override
  _NetworkStatusPageState createState() => _NetworkStatusPageState();
}

class _NetworkStatusPageState extends State<NetworkStatusPage> {
  String _status = '检查中...';
  StreamSubscription<ConnectivityResult>? _subscription;

  @override
  void initState() {
    super.initState();
    _getStatus();
    _subscription = Connectivity().onConnectivityChanged.listen((result) {
      _updateStatus(result);
    });
  }

  Future<void> _getStatus() async {
    final result = await Connectivity().checkConnectivity();
    _updateStatus(result);
  }

  void _updateStatus(ConnectivityResult result) {
    setState(() {
      _status = result.toString().split('.').last;
    });
  }

  @override
  void dispose() {
    _subscription?.cancel();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: Text('网络状态')),
      body: Center(child: Text('当前网络: $_status')),
    );
  }
}

注意事项:

  • 需要 Android 权限:<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
  • iOS 无需额外配置
  • 该包只能检测网络类型,不能保证真实网络可达性(如需检测实际连接,可结合 http 包请求测试)

使用这种方式可以方便地监控和管理应用的网络连接状态。

回到顶部