HarmonyOS NEXT——【鸿蒙监听网络状态变化】

当在鸿蒙应用中,网络状态发生变化,我们需要实现监听网络状态的变化,做出相对应的提示,比如退出登录或者退出应用之类的操作。那么我们需要监听当前网络的状态,以下是我封装的代码提供参考:

效果:

参考代码:

TypeScript 复制代码
import { connection } from '@kit.NetworkKit';
import { BusinessError } from '@kit.BasicServicesKit';
import { CommonConstants } from '../constants/CommonConstants';
import { JumpTool } from '.';
import { DialogContents, H5ShowCommonDialog } from '../../view/H5CommonDialog';
import { WindowUtils } from '../constants/WindowUtils';
import { LoginTool } from './LoginTool';
import Logger from './Logger';
​
export class ListenNetworkState {
  private static oldNetType: string | null = null
  private static newNetType: string | null = null
​
  /**
   *  获取旧网络
   * @param
   * @returns
   */
  static async getOldNet() {
    connection.getDefaultNet().then((netHandle: connection.NetHandle) => {
      if (netHandle.netId == 0) {
        // 当前没有已连接的网络时,获取的netHandler的netid为0,属于异常场景,此处可以实际情况自行添加一些处理机制。
        return;
      }
      connection.getNetCapabilities(netHandle, (error: BusinessError, data: connection.NetCapabilities) => {
        if (error) {
          return;
        }
        // Logger.info("Succeeded to get data: " + JSON.stringify(data));
        if (data.bearerTypes[0] == 0) {
          ListenNetworkState.oldNetType = '蜂窝网络'
          // promptAction.showToast({ message: '蜂窝网络' })
        }
        if (data.bearerTypes[0] == 1) {
          ListenNetworkState.oldNetType = 'Wi-Fi网络'
          // promptAction.showToast({ message: 'Wi-Fi网络' })
        }
      })
    }).catch((error: BusinessError) => {
    });
  }
​
  /**
   * 监听网络是否变化
   * @param
   * @returns true 变化 false 无变化
   */
  static async listenNetwork() {
    let isNetworkChanged = false;
    await ListenNetworkState.getOldNet();
    let currentNet = connection.createNetConnection();
    currentNet.register((error) => {
      if (error) {
        // Logger.info('订阅失败' + JSON.stringify(error));
      } else {
        // Logger.info('订阅成功' + JSON.stringify(error));
      }
    });
​
    //网络切换时
    currentNet.on("netCapabilitiesChange", (data) => {
      if (data.netCap.bearerTypes[0] == 0) {
        ListenNetworkState.newNetType = '蜂窝网络';
      }
      if (data.netCap.bearerTypes[0] == 1) {
        ListenNetworkState.newNetType = 'Wi-Fi网络';
      }
      if (ListenNetworkState.oldNetType !== ListenNetworkState.newNetType) {
        if (CommonConstants.ISLOGIN) {
          LoginTool.logOut(false, false)
​
          let context: DialogContents = {
            title: "提示",
            message: '网络发生变化,已退出登录',
            confirms: () => {
              WindowUtils.getRouter().pushUrl({ url: 'pages/login/LoginPwdPage' })
            }
          }
          H5ShowCommonDialog(context)
        }
        ListenNetworkState.oldNetType = ListenNetworkState.newNetType
      }
    });
​
    //无网络切换到有网络时
    currentNet.on("netAvailable", (data) => {
​
      if (CommonConstants.ISLOGIN) {
        LoginTool.logOut(false, false)
​
        let context: DialogContents = {
          title: "提示",
          message: '网络发生变化,已退出登录',
          confirms: () => {
            WindowUtils.getRouter().pushUrl({ url: 'pages/login/LoginPwdPage' })
          }
        }
        H5ShowCommonDialog(context)
      }
    });
  }
}
相关推荐
人工智能知识库1 分钟前
华为HCIA-AI Solution H13-313题库(带详细解析)
人工智能·华为·hcia-ai·h13-313
kirk_wang9 分钟前
当Flutter的并发利器遇上鸿蒙:flutter_isolate的OHOS适配之旅
flutter·移动开发·跨平台·arkts·鸿蒙
Van_captain26 分钟前
rn_for_openharmony常用组件_Tabs选项卡
javascript·开源·harmonyos
特立独行的猫a27 分钟前
低成本搭建鸿蒙PC运行环境:基于 Docker 的 x86_64 服务器
docker·容器·harmonyos·鸿蒙pc
Van_captain1 小时前
React Native for OpenHarmony Toast 轻提示组件:自动消失的操作反馈
javascript·开源·harmonyos
Van_captain1 小时前
React Native for OpenHarmony Modal 模态框组件:阻断式交互的设计与实现
javascript·开源·harmonyos
cn_mengbei1 小时前
鸿蒙原生PC应用开发实战:从零搭建到性能优化,掌握ArkTS与DevEco Studio高效开发技巧
华为·性能优化·harmonyos
前端世界1 小时前
鸿蒙应用为什么会卡?一次 DevEco Profiler 的真实性能分析实战
华为·harmonyos
wei_shuo1 小时前
最佳实践 - ArkTS 驱动鸿蒙元服务开发:从界面布局到交互逻辑,打造多功能决策类元服务
arkts·鸿蒙·元服务
cn_mengbei2 小时前
鸿蒙PC原生应用开发避坑指南:Qt 6.6与Electron 28兼容性问题全解析
qt·electron·harmonyos