统计网络流量消耗
简介
流量管理提供了基于物理网络的数据流量统计能力,支持基于网卡/UID 的流量统计。
流量管理主要实现功能有:
- 支持基于网卡/UID 的实时流量统计。
- 支持基于网卡/UID 的历史流量统计。
- 支持基于网卡/UID 的流量变化订阅。
说明: 为了保证应用的运行效率,大部分 API 调用都是异步的,对于异步调用的 API 均提供了 callback 和 Promise 两种方式,以下示例均采用 Promise 函数,更多方式可以查阅@ohos.net.statistics (流量管理)。
以下分别介绍具体开发方式。
开发步骤
-
导入statistics、socket以及错误码模块。
import { socket, statistics } from '@kit.NetworkKit'; import { BusinessError } from '@kit.BasicServicesKit'; import { hilog } from '@kit.PerformanceAnalysisKit'; -
获取指定网卡实时流量数据
调用getIfaceRxBytes接口传入网卡名获取实时下行流量数据。
// wlan0为主WiFi网卡名,获取主WiFi实时下行流量数据。 statistics.getIfaceRxBytes('wlan0').then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }) .catch((err: BusinessError) => { hilog.error(0x0000, 'testTag', JSON.stringify(err)); // ... }); // ... // wlan0为主WiFi网卡名,获取主WiFi实时上行流量数据。 statistics.getIfaceTxBytes('wlan0').then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }) .catch((err: BusinessError) => { hilog.error(0x0000, 'testTag', JSON.stringify(err)); // ... }); // ... -
获取蜂窝实时流量数据
调用getCellularRxBytes接口获取蜂窝实时上下行流量数据。
// 获取蜂窝实时下行流量数据。 statistics.getCellularRxBytes().then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }) // ... // 获取蜂窝实时上行流量数据。 statistics.getCellularTxBytes().then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }) // ... -
获取所有网卡实时流量数据
调用getAllRxBytes接口获取所有网卡实时上下行流量数据。
// 获取所有网卡实时下行流量数据。 statistics.getAllRxBytes().then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }) // ... // 获取所有网卡实时上行流量数据。 statistics.getAllTxBytes().then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }) // ... -
获取指定应用实时流量数据
调用getUidRxBytes接口,传入UID获取指定应用实时上下行流量数据。
let UID = 20010038;// 获取指定应用实时下行流量数据。 // ... statistics.getUidRxBytes(UID).then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }) // ... // 获取指定应用实时上行流量数据。 // ... statistics.getUidTxBytes(UID).then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }) // ... -
获取指定socket实时流量数据
调用getSockfdRxBytes接口,传入指定的sockFd获取指定socket实时上下行流量数据。
// 获取指定socket实时下行流量数据。 let tcp: socket.TCPSocket = socket.constructTCPSocketInstance(); // ... tcp.getSocketFd().then((sockfd: number) => { statistics.getSockfdRxBytes(sockfd).then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }).catch((err: BusinessError) => { hilog.error(0x0000, 'testTag', JSON.stringify(err)); // ... }); }) // ... // 获取指定socket实时上行流量数据。 tcp.getSocketFd().then((sockfd: number) => { statistics.getSockfdTxBytes(sockfd).then((stats: number) => { hilog.info(0x0000, 'testTag', JSON.stringify(stats)); // ... }).catch((err: BusinessError) => { hilog.error(0x0000, 'testTag', JSON.stringify(err)); // ... }); }) // ...
获取网卡/UID 的历史流量统计数据
-
获取指定网卡历史流量信息。
-
获取指定应用历史流量信息。
import { statistics } from '@kit.NetworkKit'; class IfaceInfo { iface: string = "wlan0" startTime: number = 1685948465 endTime: number = 16859485670 } // 获取指定网卡历史流量信息。 statistics.getTrafficStatsByIface(new IfaceInfo()).then((statsInfo: statistics.NetStatsInfo) => { console.info( "getTrafficStatsByIface bytes of received = " + JSON.stringify(statsInfo.rxBytes) ); console.info( "getTrafficStatsByIface bytes of sent = " + JSON.stringify(statsInfo.txBytes) ); console.info( "getTrafficStatsByIface packets of received = " + JSON.stringify(statsInfo.rxPackets) ); console.info( "getTrafficStatsByIface packets of sent = " + JSON.stringify(statsInfo.txPackets) ); }); class UidInfo { uid: number = 20010037 ifaceInfo: IfaceInfo = new IfaceInfo() } let uidInfo = new UidInfo() // 获取指定应用历史流量信息。 statistics.getTrafficStatsByUid(uidInfo).then((statsInfo: statistics.NetStatsInfo) => { console.info("getTrafficStatsByUid bytes of received = " + JSON.stringify(statsInfo.rxBytes)); console.info("getTrafficStatsByUid bytes of sent = " + JSON.stringify(statsInfo.txBytes)); console.info("getTrafficStatsByUid packets of received = " + JSON.stringify(statsInfo.rxPackets)); console.info("getTrafficStatsByUid packets of sent = " + JSON.stringify(statsInfo.txPackets)); })
订阅流量变化事件
-
订阅流量改变事件通知。
-
取消订阅流量改变事件通知。
import { statistics } from '@kit.NetworkKit'; class Data { iface: string = "" uid?: number = 0 } let callback = (data: Data) => { console.info('on netStatsChange, data:' + JSON.stringify(data)); }; // 订阅流量改变事件通知。 statistics.on('netStatsChange', callback); // 取消订阅流量改变事件通知。可以指定传入on中的callback取消一个订阅,也可以不指定callback清空所有订阅。 statistics.off('netStatsChange', callback); statistics.off('netStatsChange');
相关实例
针对流量管理的开发,有以下相关实例可供参考: