1# 流量管理
2
3## 简介
4
5流量管理提供了基于物理网络的数据流量统计能力,支持基于网卡/UID 的流量统计。
6
7流量管理主要实现功能有:
8
9- 支持基于网卡/UID 的实时流量统计。
10- 支持基于网卡/UID 的历史流量统计。
11- 支持基于网卡/UID 的流量变化订阅。
12
13> **说明:**
14> 为了保证应用的运行效率,大部分 API 调用都是异步的,对于异步调用的 API 均提供了 callback 和 Promise 两种方式,以下示例均采用 Promise 函数,更多方式可以查阅[API 参考](../reference/apis-network-kit/js-apis-net-statistics.md)。
15
16以下分别介绍具体开发方式。
17
18## 接口说明
19
20完整的 JS API 说明以及实例代码请参考:[statistics 链接](../reference/apis-network-kit/js-apis-net-statistics.md)。
21
22| 接口名                                                       | 描述                                                         |
23| ------------------------------------------------------------ | ------------------------------------------------------------ |
24| getIfaceRxBytes(nic: string, callback: AsyncCallback\<number>): void; | 获取指定网卡实时下行流量数据。                               |
25| getIfaceTxBytes(nic: string, callback: AsyncCallback\<number>): void; | 获取指定网卡实时上行流量数据。                               |
26| getCellularRxBytes(callback: AsyncCallback\<number>): void;  | 获取蜂窝实时下行流量数据。                                   |
27| getCellularTxBytes(callback: AsyncCallback\<number>): void;  | 获取蜂窝实时上行流量数据。                                   |
28| getAllRxBytes(callback: AsyncCallback\<number>): void;       | 获取所有网卡实时下行流量数据。                               |
29| getAllTxBytes(callback: AsyncCallback\<number>): void;       | 获取所有网卡实时上行流量数据。                               |
30| getUidRxBytes(uid: number, callback: AsyncCallback\<number>): void; | 获取指定应用实时下行流量数据。                               |
31| getUidTxBytes(uid: number, callback: AsyncCallback\<number>): void; | 获取指定应用实时上行流量数据。                               |
32| <!--DelRow-->getTrafficStatsByIface(ifaceInfo: IfaceInfo, callback: AsyncCallback\<NetStatsInfo>): void; | 获取指定网卡历史流量信息。系统接口,[详情参考文档](../reference/apis-network-kit/js-apis-net-statistics-sys.md#statisticsgettrafficstatsbyiface10) |
33| <!--DelRow-->getTrafficStatsByUid(uidInfo: UidInfo, callback: AsyncCallback\<NetStatsInfo>): void; | 获取指定应用历史流量信息。系统接口,[详情参考文档](../reference/apis-network-kit/js-apis-net-statistics-sys.md#statisticsgettrafficstatsbyuid10) |
34| getSockfdRxBytes(sockfd: number, callback: AsyncCallback\<number>): void; | 获取指定socket实时下行流量数据。                             |
35| getSockfdTxBytes(sockfd: number, callback: AsyncCallback\<number>): void; | 获取指定socket实时上行流量数据。                             |
36| <!--DelRow-->on(type: 'netStatsChange', callback: Callback\<{ iface: string, uid?: number }>): void; | 订阅流量改变事件通知。系统接口,[详情参考文档](../reference/apis-network-kit/js-apis-net-statistics-sys.md#statisticsonnetstatschange10) |
37| <!--DelRow-->off(type: 'netStatsChange', callback?: Callback\<{ iface: string, uid?: number }>): void; | 取消订阅流量改变事件通知。系统接口,[详情参考文档](../reference/apis-network-kit/js-apis-net-statistics-sys.md#statisticsoffnetstatschange10) |
38| <!--DelRow-->getTrafficStatsByNetwork(networkInfo: NetworkInfo): Promise\<UidNetStatsInfo\>; | 获取指定时间段内所有应用在指定网络中的流量使用详情。系统接口,[详情参考文档](../reference/apis-network-kit/js-apis-net-statistics-sys.md#statisticsgettrafficstatsbynetwork12) |
39| <!--DelRow-->getTrafficStatsByUidNetwork(uid: number, networkInfo: NetworkInfo): Promise\<NetStatsInfoSequence\>; | 获取指定时间段内,应用在指定网络中的流量使用详情。系统接口,[详情参考文档](../reference/apis-network-kit/js-apis-net-statistics-sys.md#statisticsgettrafficstatsbynetwork12) |
40
41## 获取网卡/UID 的实时流量统计数据
42
431. 获取指定网卡实时流量数据。
442. 获取蜂窝实时流量数据。
453. 获取所有网卡实时流量数据。
464. 获取指定应用实时流量数据。
475. 获取指定socket实时流量数据。
48
49```ts
50// 从@kit.NetworkKit中导入statistics命名空间
51import { statistics, socket } from '@kit.NetworkKit';
52import { BusinessError } from '@kit.BasicServicesKit';
53
54// 获取指定网卡实时下行流量数据。
55statistics.getIfaceRxBytes("wlan0").then((stats: number) => {
56  console.log(JSON.stringify(stats));
57});
58
59// 获取指定网卡实时上行流量数据。
60statistics.getIfaceTxBytes("wlan0").then((stats: number) => {
61  console.log(JSON.stringify(stats));
62});
63
64// 获取蜂窝实时下行流量数据。
65statistics.getCellularRxBytes().then((stats: number) => {
66  console.log(JSON.stringify(stats));
67});
68
69// 获取蜂窝实时上行流量数据。
70statistics.getCellularTxBytes().then((stats: number) => {
71  console.log(JSON.stringify(stats));
72});
73
74// 获取所有网卡实时下行流量数据。
75statistics.getAllRxBytes().then((stats: number) => {
76  console.log(JSON.stringify(stats));
77});
78
79// 获取所有网卡实时上行流量数据。
80statistics.getAllTxBytes().then((stats: number) => {
81  console.log(JSON.stringify(stats));
82});
83
84// 获取指定应用实时下行流量数据。
85let uid = 20010038;
86statistics.getUidRxBytes(uid).then((stats: number) => {
87  console.log(JSON.stringify(stats));
88});
89
90// 获取指定应用实时上行流量数据。
91let uids = 20010038;
92statistics.getUidTxBytes(uids).then((stats: number) => {
93  console.log(JSON.stringify(stats));
94});
95
96// 获取指定socket实时下行流量数据。
97let tcp: socket.TCPSocket = socket.constructTCPSocketInstance();
98tcp.getSocketFd().then((sockfd: number) => {
99  statistics.getSockfdRxBytes(sockfd).then((stats: number) => {
100    console.log(JSON.stringify(stats));
101  }).catch((err: BusinessError) => {
102    console.error(JSON.stringify(err));
103  });
104});
105
106// 获取指定socket实时上行流量数据。
107tcp.getSocketFd().then((sockfd: number) => {
108  statistics.getSockfdTxBytes(sockfd).then((stats: number) => {
109    console.log(JSON.stringify(stats));
110  }).catch((err: BusinessError) => {
111    console.error(JSON.stringify(err));
112  });
113});
114```
115
116<!--Del-->
117## 获取网卡/UID 的历史流量统计数据
118
1191. 获取指定网卡历史流量信息。
1202. 获取指定应用历史流量信息。
121
122```ts
123import { statistics } from '@kit.NetworkKit';
124import { BusinessError } from '@kit.BasicServicesKit';
125
126class IfaceInfo {
127  iface: string = "wlan0"
128  startTime: number = 1685948465
129  endTime: number = 16859485670
130}
131// 获取指定网卡历史流量信息。
132statistics.getTrafficStatsByIface(new IfaceInfo()).then((statsInfo: statistics.NetStatsInfo) => {
133  console.log(
134    "getTrafficStatsByIface bytes of received = " +
135    JSON.stringify(statsInfo.rxBytes)
136  );
137  console.log(
138    "getTrafficStatsByIface bytes of sent = " +
139    JSON.stringify(statsInfo.txBytes)
140  );
141  console.log(
142    "getTrafficStatsByIface packets of received = " +
143    JSON.stringify(statsInfo.rxPackets)
144  );
145  console.log(
146    "getTrafficStatsByIface packets of sent = " +
147    JSON.stringify(statsInfo.txPackets)
148  );
149});
150
151class UidInfo {
152  uid: number = 20010037
153  ifaceInfo: IfaceInfo = new IfaceInfo()
154}
155
156let uidInfo = new UidInfo()
157
158// 获取指定应用历史流量信息。
159statistics.getTrafficStatsByUid(uidInfo).then((statsInfo: statistics.NetStatsInfo) => {
160  console.log("getTrafficStatsByUid bytes of received = " + JSON.stringify(statsInfo.rxBytes));
161  console.log("getTrafficStatsByUid bytes of sent = " + JSON.stringify(statsInfo.txBytes));
162  console.log("getTrafficStatsByUid packets of received = " + JSON.stringify(statsInfo.rxPackets));
163  console.log("getTrafficStatsByUid packets of sent = " + JSON.stringify(statsInfo.txPackets));
164})
165```
166
167## 订阅流量变化事件
168
1691. 订阅流量改变事件通知。
1702. 取消订阅流量改变事件通知。
171
172```ts
173import { statistics } from '@kit.NetworkKit';
174
175class Data {
176  iface: string = ""
177  uid?: number = 0
178}
179
180let callback = (data: Data) => {
181  console.log('on netStatsChange, data:' + JSON.stringify(data));
182};
183// 订阅流量改变事件通知。
184statistics.on('netStatsChange', callback);
185
186// 取消订阅流量改变事件通知。可以指定传入on中的callback取消一个订阅,也可以不指定callback清空所有订阅。
187statistics.off('netStatsChange', callback);
188statistics.off('netStatsChange');
189```
190<!--DelEnd-->