[Harmony]网络状态监听

权限

module.json5中添加必要权限:

TypeScript 复制代码
// 声明应用需要请求的权限列表
"requestPermissions": [
  {
    "name": "ohos.permission.GET_NETWORK_INFO", // 网络信息权限
    "reason": "$string:network_info_reason",
    "usedScene": {
      "abilities": ['MFVoiceManager'],
      "when": "always"
    }
  },
  {
    "name": "ohos.permission.INTERNET", // 网络权限
    "reason": "$string:internet_reason",
    "usedScene": {
      "abilities": [],
      "when": "always"
    }
  }
],
TypeScript 复制代码
{
  "name": "network_info_reason",
  "value": "需要网络信息权限用于监听网络的变化"
},
{
  "name": "internet_reason",
  "value": "需要网络权限用来网络请求"
},

监听工具

TypeScript 复制代码
/**
 * 网络状态监听工具类
 * 功能:实时监测网络连接状态及类型变化
 */
import { connection } from '@kit.NetworkKit';
import { BusinessError } from '@kit.BasicServicesKit';
import ConsoleLog from '../extension/ConsoleLog';

// 网络类型定义
type NetworkType = 'NONE' | 'CELLULAR' | 'WIFI' | 'ETHERNET';

class NetworkMonitor {
  private static instance: NetworkMonitor;
  private netConnection?: connection.NetConnection;
  private listeners: Array<(status: NetworkType) => void> = [];

  // 单例获取
  static getInstance(): NetworkMonitor {
    if (!NetworkMonitor.instance) {
      NetworkMonitor.instance = new NetworkMonitor();
    }
    return NetworkMonitor.instance;
  }

  /**
   * 启动网络监听
   */
  startMonitoring(): void {
    try {
      this.netConnection = connection.createNetConnection();

      // 注册网络状态监听
      this.netConnection.register((err: BusinessError) => {
        if (err) {
          ConsoleLog.error(`网络状态监听注册失败: ${err.code}-${err.message}`);
        } else {
          ConsoleLog.log('网络状态监听注册成功');
        }
      });

      // 监听网络可用事件
      this.netConnection.on('netAvailable', (data: connection.NetHandle) => {
        ConsoleLog.log('网络已连接');
        this.checkNetworkType(data);
      });

      // 监听网络断开事件
      this.netConnection.on('netLost', () => {
        ConsoleLog.log('网络已断开 - 无互联网连接');
      });

      // 监听网络不可用事件
      this.netConnection.on('netUnavailable', () => {
        ConsoleLog.log('网络不可用');
      });
    } catch (error) {
      ConsoleLog.error(`NetworkMonitor Initialization error: ${error}`);
    }
  }

  // 检查当前网络类型
  checkNetworkType(netHandle: connection.NetHandle) {
    connection.getNetCapabilities(netHandle, (error: BusinessError, data: connection.NetCapabilities) => {
      if (error) {
        ConsoleLog.error('获取网络能力失败:', JSON.stringify(error));
        return;
      }

      if (data && data.bearerTypes) {
        const networkType = this.parseBearerType(data.bearerTypes[0]);
        ConsoleLog.log('当前网络类型:', networkType);
        this.triggerListeners(true, networkType); // 触发回调
      }
    });
  }

  /**
   * 解析网络承载类型
   * @param type 网络类型编码
   * @returns 标准化网络类型
   */
  private parseBearerType(type?: number): NetworkType {
    if (!type) return 'NONE';
    switch(type) {
      case connection.NetBearType.BEARER_CELLULAR: return 'CELLULAR'; // 蜂窝网络
      case connection.NetBearType.BEARER_WIFI: return 'WIFI'; // Wi-Fi
      case connection.NetBearType.BEARER_ETHERNET: return 'ETHERNET'; // 以太网
      default: return 'NONE'; // 未知网络
    }
  }

  /**
   * 注册状态监听
   * @param callback 状态变更回调函数
   */
  addListener(callback: (status: NetworkType) => void): void {
    this.listeners.push(callback);
  }

  /**
   * 移除状态监听
   * @param callback 要移除的回调函数
   */
  removeListener(callback: Function): void {
    this.listeners = this.listeners.filter(cb => cb !== callback);
  }

  // 在事件处理方法中触发回调(例如netAvailable事件)
  private triggerListeners(isConnected: boolean, type: NetworkType) {
    this.listeners.forEach(cb => cb(type));
  }
}

export const networkMonitor = NetworkMonitor.getInstance();

示例

TypeScript 复制代码
  // 窗口舞台创建回调
  onWindowStageCreate(windowStage: window.WindowStage): void {
    ...
networkMonitor.startMonitoring()
  }
相关推荐
Georgewu7 小时前
【 HarmonyOS 5 入门系列 】鸿蒙HarmonyOS示例项目讲解
harmonyos
libo_20259 小时前
HarmonyOS5 元宇宙3D原子化服务开发实践
harmonyos
半路下车9 小时前
【Harmony OS 5】DevEco Testing重塑教育质量
harmonyos·arkts
90后的晨仔9 小时前
解析鸿蒙 ArkTS 中的 Union 类型与 TypeAliases类型
前端·harmonyos
风浅月明10 小时前
[Harmony]颜色初始化
harmonyos·color
半路下车10 小时前
【Harmony OS 5】DevEco Testing在教育领域的应用与实践
harmonyos·产品
simple丶10 小时前
【HarmonyOS Relational Database】鸿蒙关系型数据库
harmonyos·arkts·arkui
哼唧唧_11 小时前
使用 React Native 开发鸿蒙(HarmonyOS)运动健康类应用的系统化准备工作
react native·react.js·harmonyos·harmony os5·运动健康
三掌柜66611 小时前
HarmonyOS开发:显示图片功能详解
华为·harmonyos