[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()
  }
相关推荐
祭曦念1 小时前
【共创季稿事节】HarmonyOS NEXT 纯百分比布局实战:RelativeContainer + alignRules 多屏适配完全指南
华为·harmonyos
风华圆舞1 小时前
在 Flutter 鸿蒙项目里接入文本转语音的完整思路
flutter·华为·harmonyos
不羁的木木1 小时前
HarmonyOS AI开发提效工具:DevEco Code & DevEco CLI - 跨设备调试与AI应用部署
人工智能·华为·harmonyos·鸿蒙
金启攻2 小时前
【鸿蒙原生应用开发实战】第一篇:项目搭建与首页开发 — 从零构建“宇宙探索“App
harmonyos
坚果派·白晓明3 小时前
鸿蒙 PC应用集成 hwloc:3 大 NAPI & 编译坑详解
c语言·华为·ai编程·harmonyos·atomcode
不羁的木木3 小时前
HarmonyOS AI开发提效工具:DevEco Code & DevEco CLI - AOT编译加速AI应用启动
harmonyos·鸿蒙
木咺吟4 小时前
鸿蒙原生应用实战(三):塔罗牌App开发 — 牌阵解读与交互设计
harmonyos
不喝水就会渴4 小时前
HarmonyOS惰性加载性能优化技术详解(喵屿项目案例)
华为·性能优化·harmonyos
轻口味4 小时前
轻规划鸿蒙开发实战9:对接 Agent Framework Kit,用小艺智能体实现愿景项目体检与自动可行性打分
华为·harmonyos
祭曦念4 小时前
【共创季稿事节】鸿蒙原生 ArkTS 布局精讲:foregroundColor 前景色统一着色
华为·harmonyos