安卓NetworkStatsManager使用及demo

目录

  • 一、TrafficStats类简介
  • 二、demo示例


一、TrafficStats类简介

TrafficStats
Android API 8提供了android.net.TrafficStats类。
通过此类能获取设备重启以来网络信息,部分函数如下所示:

static long  getMobileRxBytes()  //获取通过移动数据网络收到的字节总数
static long  getMobileTxBytes()  //通过移动数据网发送的总字节数  
static long  getTotalRxBytes()  //获取设备总的接收字节数 
static long  getTotalTxBytes()  //获取设备总的发送字节数
static long  getUidRxBytes(int uid)  //获取指定uid的接收字节数  
static long  getUidTxBytes(int uid) //获取指定uid的发送字节数 

通过文档及上述函数可以知道,TrafficStats能够获取设备的数据流量和总的网络流量消耗(一般情况下也就得到Wi-Fi下的流量信息);可以查询uid对应的流量信息,而uid可以通过应用的包名查询到,因此能够查询某个应用的流量统计信息(不考虑shareuid)。非常方便的是,它的使用不需要特别的权限。另一方面它也一些限制:

(1)无法获取应用的数据流量消耗
从文档中仅能获取到指定uid的流量,但无法区分不同网络类型下的消耗
间接方法是通过监听网络切换,做好流量记录(但是要保证你的应用一直存活,且一定准确接收到网络切换信息),基本不可用。
(2)无法获取某个时间段内的流量消耗
从API文档中看,函数参数没有与时间相关的信息。而且重要的一点是,TrafficStats类中记录的是设备重启以来的流量统计信息。因为TrafficStats 类,底层还是读取/proc/net/xt_qtaguid/stats 对内容进行解析,将得到对应的结果返回上层。

链接:
Android应用流量统计——NetworkStatsManager使用

二、demo示例

本地使用demo验证流量消耗情况:获取一段时间内哪些应用进行了网络访问以及具体的流量消耗情况

package com.android.networktest;import android.app.AppOpsManager;
import android.app.usage.NetworkStats;
import android.app.usage.NetworkStatsManager;
import android.content.Context;
import android.content.Intent;
import android.net.ConnectivityManager;
import android.os.Build;
import android.os.Bundle;
import android.os.RemoteException;
import android.provider.Settings;
import android.util.Log;import androidx.appcompat.app.AppCompatActivity;public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);hasPermissionToReadNetworkStats();test();}private boolean hasPermissionToReadNetworkStats() {if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) {return true;}final AppOpsManager appOps = (AppOpsManager) getSystemService(Context.APP_OPS_SERVICE);int mode = appOps.checkOpNoThrow(AppOpsManager.OPSTR_GET_USAGE_STATS,android.os.Process.myUid(), getPackageName());if (mode == AppOpsManager.MODE_ALLOWED) {return true;}requestReadNetworkStats();return false;}// 打开“有权查看使用情况的应用”页面private void requestReadNetworkStats() {Intent intent = new Intent(Settings.ACTION_USAGE_ACCESS_SETTINGS);startActivity(intent);}public void test() {NetworkStatsManager networkStatsManager = (NetworkStatsManager) getSystemService(Context.NETWORK_STATS_SERVICE);long startTime = System.currentTimeMillis() - 1000 * 60 * 1000; // 从过去60x1000秒开始计算long endTime = System.currentTimeMillis();NetworkStats networkStats = null;NetworkStats.Bucket bucket = new NetworkStats.Bucket();try {networkStats = networkStatsManager.querySummary(ConnectivityManager.TYPE_WIFI,"",startTime,endTime);} catch (RemoteException e) {throw new RuntimeException(e);}networkStats.getNextBucket(bucket); // 获取第一个Bucketdo {// 获取应用程序UIDint uid = bucket.getUid();// 获取应用程序名称String packageName = getPackageManager().getNameForUid(uid);// 获取应用程序消耗的数据量long rxBytes = bucket.getRxBytes();long txBytes = bucket.getTxBytes();Log.d("henry------NetworkStats", "App: " + packageName + "  uid : " + uid +" RX bytes: " + rxBytes + ", TX bytes: " + txBytes);} while (networkStats.getNextBucket(bucket)); // 获取下一个Bucket,直到没有更多Bucket为止}
}

Manifest权限添加一下:

    <uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.READ_PHONE_STATE" /><uses-permission android:name="android.permission.PACKAGE_USAGE_STATS" tools:ignore="ProtectedPermissions"/>

LOG打印如下:
在这里插入图片描述
在这里插入图片描述

可以看到对应uid 所消耗的流量情况
但是uid为1000 即系统权限的应用有很多,无法进一步区分哪些系统应用默认进行了网络访问。

NetworkStatsManager底层调用的是如下节点的数据:可以看多最多细分只能划分到uid。
在这里插入图片描述
总结:
NetworkStatsManager主要用来获取三方应用用户自行下载的app流量所消耗的情况,对于系统权限uid,uid相同但非同一个应用的app或服务无法进一步区分。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/3758.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开放式激光振镜运动控制器的视觉校正振镜精度解决方案

市场应用背景 激光振镜控制系统因具有惯量小、低负载、响应速度极快等优点&#xff0c;非常适合高速微加工应用&#xff0c;如激光标刻、焊接、3D打印和精密切割等应用。 激光振镜控制系统主要涵盖了激光振镜控制和图形校正等两个技术层面&#xff0c;来共同控制激光在加工过…

Python序列解包

同行交流群问题 在Python中&#xff0c;以下哪个选项用于序列解包(unpacking)? A.split() B.unpack() C.* D.unpacking() 3 2 1 答案是C&#xff0c;你答对了吗&#xff1f; 解析&#xff1a; 1.split()是字符串方法,用于将字符串按指定分隔符分割成列表,与解包无关。 …

【自动化测试入门】Selenium基础(建议收藏)

&#x1f525; 交流讨论&#xff1a;欢迎加入我们一起学习&#xff01; &#x1f525; 资源分享&#xff1a;耗时200小时精选的「软件测试」资料包 &#x1f525; 教程推荐&#xff1a;火遍全网的《软件测试》教程 &#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1…

天星金融积极履行社会责任,扎实开展个人信息保护宣传工作

随着互联网的迅猛发展&#xff0c;网络已成为人们生活中不可或缺的一部分。然而&#xff0c;伴随着网络的普及&#xff0c;网络安全问题也愈发凸显&#xff0c;个人信息的保护显得尤为重要。为此&#xff0c;天星金融携手北京反诈中心&#xff0c;共同推出了防骗专题——《警惕…

快速上手canvas

什么是Canvase Canvas 是 HTML5 中的一个重要特性&#xff0c;它允许你使用 JavaScript 在网页上动态绘制图形。Canvas 通过 JavaScript 来控制&#xff0c;在 HTML 页面中创建一个画布元素 <canvas>&#xff0c;然后使用 JavaScript 中的 Canvas API 来进行绘制。 用法…

【Android】 四大组件详解之广播接收器、内容提供器

目录 前言广播机制简介系统广播动态注册实现监听网络变化静态注册实现开机自启动 自定义广播发送标准广播发送有序广播 本地广播 内容提供器简介运行时权限访问其他程序中的数据ContentResolver的基本用法读取系统联系人 创建自己的内容提供器创建内容提供器的步骤 跨程序数据共…

封装一个antd的Table操作项中的一个展开与收起通用功能

第一种方法,不使用任何插件和库 import React, { useState, useEffect, SetStateAction, Dispatch } from react; // 定义expandedKeys的类型 type ExpandedKeysType Set<string>; // 自定义Hook&#xff1a;useExpandedKeys function useExpandedKeys(initialK…

Vue项目中异步组件的引入使用

要在Vue项目中引入异步组件&#xff0c;可以使用defineAsyncComponent函数&#xff08;在Vue 3中&#xff09;或者在组件的定义中使用动态import&#xff08;在Vue 2和Vue 3中都支持&#xff09;。 Vue 3 使用 defineAsyncComponent import { defineAsyncComponent } from vu…

vivado 创建和运行链路清扫

创建和运行链路清扫 要分析给定链路的裕度 &#xff0c; 利用不同 MGT 设置来多次运行链路扫描是很有效的。这样有助于判定最佳设置。 Vivado Serial I/O Analyzer 功能支持您定义、运行、保存和重新调用链路清扫 &#xff0c; 链路清扫是由多次链路扫描集合而成的。 每条…

HTML中的文档声明

前言 什么是<!DOCTYPE>&#xff1f;是否需要在 HTML5 中使用&#xff1f;什么是严格模式与混杂模式&#xff1f; 文档声明概念 HTML 文档通常以文档声明开始&#xff0c;该声明的作用是帮助浏览器确定其尝试解析和显示的 HTML 文档类型。 <!DOCTYPE html>文档声…

《AI聊天类工具之三——Bing新必应》

一.简介 官网:必应 Bing新必应(New Bing)是微软公司推出的一款结合了AI功能的在线服务平台,旨在为用户提供更丰富、个性化、可靠的搜索和服务体验。它不仅可以提供传统的网页、图片、视频、地图等搜索结果,还能通过聊天模式与用户进行自然语言交互,回答各种问题,甚至生…

【源码】Spring validation参数校验实现原理总结

Spring validation参数校验系列 1、Spring validation参数校验基本使用 2、Spring validation参数校验之自定义校验规则及编程式校验等进阶篇 3、【源码】Spring validation参数校验原理解析之Controller控制器参数校验中RequestBody参数校验实现原理 4、【源码】Spring va…

Allure精通指南(05)定制化报告内容(环境信息、图标、缺陷类别)

文章目录 Allure 自定义测试环境信息Allure 自定义缺陷类别信息Allure 自定义图标步骤一步骤二步骤三 Allure 自定义测试环境信息 步骤 1&#xff1a;创建 environment.properties 文件 在项目根目录或任何其他不会被--clean-alluredir参数影响的目录下创建 environment.proper…

【链表】Leetcode K个一组翻转链表

题目讲解 25. K 个一组翻转链表 算法讲解 虽然这道题是一道困难题&#xff0c;但是从代码层面很简单&#xff0c;只是一道简单的模拟&#xff1a;我们要先求出总共需要翻转的链表有多少组&#xff08;链表的长度 / k&#xff09;&#xff0c;接下来就是翻转k的链表最链接的问…

【Nginx】(一) Nginx全方位解析:特性、功能、优缺点及应用场景

Nginx概览 Nginx&#xff08;发音为“engine-x”&#xff09;是一款开源的高性能Web服务器和反向代理服务器&#xff0c;最初由俄罗斯开发者伊戈尔赛索耶夫开发。自从2004年发布以来&#xff0c;Nginx因其轻量级、高并发处理能力、稳定性以及丰富的功能集而广受欢迎。 Nginx有…

Tomcat安装步骤及详细配置教程(2022最新版)

网上的tomcat安装及配置教程一大堆&#xff0c;但是好多都过时了&#xff0c;根本不适用现在的版本&#xff0c;今天凯歌整理一篇Tomcat安装步骤及详细配置教程&#xff0c;2022年最新版~ Tomcat安装及配置教程主要分为四步&#xff1a; 步骤一&#xff1a;首先确认自己是否已…

【C++进阶之路】C++11(下) —— 线程库

序言 本篇文章主要是填之前C11留下的坑以及了解与熟悉线程库&#xff0c;有读者感兴趣之前的内容的话可见「C进阶之路」专栏中标题为「C11」的内容&#xff0c;废话不多说&#xff0c;先来概括一下本文的内容&#xff0c;首先我们会从历史的角度分别谈及Linux以及Windows下的线…

uniapp如何调起WhatsApp发送消息?

如何给WhatsApp发送消息&#xff1f; 通过点击链接发送 通过 a 标签&#xff0c;点击链接发送消息 <a href"https://wa.me/手机号?text内容"></a>// 例&#xff1a; <a href"https://wa.me/8562024899136?textHello"></a>通过…

JavaEE 初阶篇-深入了解 I/O 高级流(缓冲流、交换流、数据流和序列化流)

&#x1f525;博客主页&#xff1a; 【小扳_-CSDN博客】 ❤感谢大家点赞&#x1f44d;收藏⭐评论✍ 文章目录 1.0 缓冲流概述 1.1 缓冲流的工作原理 1.2 使用缓冲流的步骤 1.3 字节缓冲流于字符缓冲流的区别 1.4 字节缓冲流的实例 1.5 字符缓冲流的实例 2.0 转换流概述 2.1 字符…

13-Makefile_04

使用函数 在更复杂的工程中&#xff0c;头文件、源文件可能会放在二级目录&#xff0c;为了实现这种操作通常需要使用Makefile的函数。 函数格式及示例 在Makefile中调用函数的方法跟变量的使用类似&#xff0c;以“$()”或“${}”符号包含函数名和参数&#xff0c;具体语法…