美文网首页Flutter开发圈FlutterFlutter
Flutter-手机网络状态监听

Flutter-手机网络状态监听

作者: FJK | 来源:发表于2019-01-14 14:58 被阅读1832次

前言

在Android中会在基础类中监听手机的网络状态,并作出相应的提示,在Flutter 中也提供了相应的package,但是略有不同;

1.依赖

dependencies:
  connectivity: ^0.3.2

2.导入

import 'package:flutter_cache_manager/flutter_cache_manager.dart';

3.简单使用

检查当前网络状态

注意:在Android上,这并不保证连接到Internet。例如,该应用程序可能有WiFi接入,但可能是VPN或没有接入的酒店WiFi。也就是说网络状态是'wifi',也不代表你的手机能进行网络访问。

import 'package:connectivity/connectivity.dart';

var connectivityResult = await (new Connectivity().checkConnectivity());
if (connectivityResult == ConnectivityResult.mobile) {
  // I am connected to a mobile network.
} else if (connectivityResult == ConnectivityResult.wifi) {
  // I am connected to a wifi network.
}

监听网络状态

请注意,不应该使用当前的网络状态来决定是否可以可靠地进行网络连接。
网络层可能会出现超时和错误,需要在应用程序代码中做好异常处理;

import 'package:connectivity/connectivity.dart';

initState() {
  subscription = new Connectivity().onConnectivityChanged.listen((ConnectivityResult result) {
    // Got a new connectivity status!
  })
}

// Be sure to cancel subscription after you are done
dispose() {
  subscription.cancel();
}

4.例子

import 'dart:async';

import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:connectivity/connectivity.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key, this.title}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  String _connectionStatus = 'Unknown';
  final Connectivity _connectivity = Connectivity();
  StreamSubscription<ConnectivityResult> _connectivitySubscription;

  @override
  void initState() {
    super.initState();
    initConnectivity();
    _connectivitySubscription =
        _connectivity.onConnectivityChanged.listen((ConnectivityResult result) {
      setState(() => _connectionStatus = result.toString());
    });
  }

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

   //平台消息是异步的,所以我们用异步方法初始化。
  Future<Null> initConnectivity() async {
    String connectionStatus;
    //平台消息可能会失败,因此我们使用Try/Catch PlatformException。
    try {
      connectionStatus = (await _connectivity.checkConnectivity()).toString();
    } on PlatformException catch (e) {
      print(e.toString());
      connectionStatus = 'Failed to get connectivity.';
    }

    // 如果在异步平台消息运行时从树中删除了该小部件,
    // 那么我们希望放弃回复,而不是调用setstate来更新我们不存在的外观。
    if (!mounted) {
      return;
    }

    setState(() {
      _connectionStatus = connectionStatus;
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Plugin example app'),
      ),
      body: Center(child: Text('Connection Status: $_connectionStatus\n')),
    );
  }
}

5.tips

wifi移动网络 同时存在时,监听中提示当前网络wifi;并且此时断开或者连接移动网络无回调

6.遇到的问题

在华为GAR-TL00,Android 版本5.0.1,EMUI 系统3.1,无Sim卡的测试机上,关闭和打开wifi,会有网络变化回调,但是回调的结果都是wifi,没查到什么原因,另外的手机目前回调都正常;

7.资料参考

https://pub.dartlang.org/packages/connectivity

  • 这个网址提供了很多兼容Android 和 IOS 的 package;

相关文章

  • Flutter-手机网络状态监听

    前言 在Android中会在基础类中监听手机的网络状态,并作出相应的提示,在Flutter 中也提供了相应的pac...

  • AFNetworking <一> AFNetwork

    AFNetworkReachabilityManager 是用来实时监听网络状态的。具体来说,是监听手机(主机)是...

  • uni-app 监听网络状态

    在 app 页面中监听当前用户手机网络的连接状态 以及 网络类型

  • 监听网络状态

    监听网络状态 在日常开发中,我们经常会遇到这种情况,需要我们对手机的网络状态进行监听 比如:播放视频需要提示是4G...

  • AFNetwork

    //设置网络监听 (void)monitorNetworking{//监听网络状态AFNetworkReachab...

  • 网络状态监听

  • 监听网络状态

    在项目中导入Reachability.h和Reachability.m文件,地址:Reachability Vie...

  • 监听网络状态

    如果用系统的方法需要导入 Reachability.h Reachability.m @interface Vie...

  • 网络状态监听

    监听网络变化在开发中是经常用到的,例如我们断网有一些友好的提示,或者根据不同的网络更改一些加载策略,例如wifi看...

  • 网络状态监听

    一、在 AppDelegate.m 中创建监听单例,并监听发起通知 二、在任意地方接收状态通知,此非block通知...

网友评论

    本文标题:Flutter-手机网络状态监听

    本文链接:https://www.haomeiwen.com/subject/cveddqtx.html