当前位置: 首页 > news >正文

App测试之App日志收集及adb常用命令

文章目录

  • 前言
  • 一、adb是什么
    • 1.APP测试收集手机日志常用的工具
    • 2.adb下载与安装
    • 3.ADT/SDK/ADB是什么
    • 4.adb连接真机
  • 二、adb常用命令
  • 三、android系统日志文件
    • 1.logcat日志文件
    • 2.logcat日志文件分析
  • 四、分析crash & ANR 日志
    • 1.发生crash如何分析
    • 2.发生ANR如何分析
  • 总结
    • 扩展(IOS app定位日志)

前言

adb的全称为Android Debug Bridge,就是起到调试桥的作用。通过adb可以在Eclipse中通过DDMS来调试Android程序,说白了就是调试工具。

adb的工作方式比较特殊,采用监听Socket TCP 5554等端口的方式让IDE和Qemu通讯,默认情况下adb会daemon相关的网络端口,所以当我们运行Eclipse时adb进程就会自动运行。

  • adb是android sdk里的一个工具,用这个工具可以直接操作管理android模拟器或者真实的android设备,它的主要功能有:
    • 运行设备的shell(命令行)
    • 管理模拟器或设备的端口映射
    • 计算机和设备之间上传/下载文件
    • 将本地apk软件安装至模拟器或android设备

ADB是一个 客户端-服务器端 程序, 其中客户端是你用来操作的电脑,,服务器端是android设备

一、adb是什么

1.APP测试收集手机日志常用的工具

  1. ADT

    收集开发人员使用最多的开发工具,也是可以实现从pc端获取手机端的文件

  2. SDK

    收集开发人员使用最多的开发工具,也是可以实现从pc端获取手机端的文件

  3. ADB

    测试人员最常用的工具,通过pc端收集手机端的文件

2.adb下载与安装

  • adb下载与安装:https://blog.csdn.net/weixin_44904239/article/details/134733985

3.ADT/SDK/ADB是什么

  • ADT

    ADT(Android development tools)——Android开发工具。在Eclipse上调用各种与android有关的插件,便要ADT。

  • SDK

    SDK(software development kit)——软件开发工具包。要用到各种android平台,好比android2.3等,便要有SDK

  • ADB

    ADB(Android debug bridge)——安卓调试桥。是用来连接安卓手机和PC端的桥梁,通过adb服务,在PC端命令行界面对手机或者模拟器进行全面的操作

    adb的全称为Android Debug Bridge,就是起到调试桥的作用。通过adb可以在Eclipse中通过DDMS来调试Android程序,说白了就是调试工具。

    adb的工作方式比较特殊,采用监听Socket TCP 5554等端口的方式让IDE和Qemu通讯,默认情况下adb会daemon相关的网络端口,所以当我们运行Eclipse时adb进程就会自动运行。

    • adb是android sdk里的一个工具,用这个工具可以直接操作管理android模拟器或者真实的android设备,它的主要功能有:
      • 运行设备的shell(命令行)
      • 管理模拟器或设备的端口映射
      • 计算机和设备之间上传/下载文件
      • 将本地apk软件安装至模拟器或android设备

    ADB是一个 客户端-服务器端 程序, 其中客户端是你用来操作的电脑,,服务器端是android设备

4.adb连接真机

  • 方法一:USB连接调试

    • 1.使用usb数据线连接好电脑

    • 2.手机打开调试模式,勾选usb调试模式(每个手机打开方式不一样,找不到可以通过百度查找)
      参考链接:https://support.oppo.com/cn/answer/?aid=SI2105995
      在这里插入图片描述

    • 3.电脑端打开命令提示符,输入adb devices 检测,能出现设备列表代表连接成功

      在这里插入图片描述

  • 方法二:Wifi连接调试

    Android设备与将运行 adb 的电脑连接到同一个局域网,比如连到同一个 WiFi

    • 1.使用usb数据线连接好电脑

    • 2.打开命令提示符,运行adb devices,测试是否连接成功,能出现设备列表即可

      在这里插入图片描述

    • 3.运行adb tcpip 5555(另外设立一个端口,实现手机与电脑的连接),然后断开USB连接

      在这里插入图片描述

    • 4.通过手机状态信息,查看手机的IP地址(一般会在 设置-关于手机-状态信息 里面)
      在这里插入图片描述

    • 5.运行 adb connect 手机IP地址,若出现:connected to 手机IP地址:5555 说明连接成功

      adb connect 192.168.31.36	若出现:connected to 192.168.31.36:5555 说明连接成功
      

      在这里插入图片描述

    • 6.输入adb devices检测是否连接成功

      在这里插入图片描述

二、adb常用命令

  • 查看帮助手册

    adb --help
    
  • 查看连接设备(检测连接到电脑的设备)

    adb devices
    

    在这里插入图片描述

  • 根据IP地址连接对应设备

    adb connect 要连接设备的IP地址
    

    在这里插入图片描述

  • 登陆设备shell(进入到 linux命令环境了,相当于执行远程命令)

    adb shell	#使用exit命令退出
    

    在这里插入图片描述

  • 从手机中拉取信息放到本地电脑上

    adb pull 手机文件路径 电脑端路径
    

    例子

    #将手机/sdcard/Android/data目录下的Test.txt文件拉取到电脑端的D盘根目录下
    adb pull /sdcard/Android/data/Test.txt D:\
    

    在这里插入图片描述

  • 从本地推送信息到手机上去

    adb push 电脑端文件路径 手机端路径
    

    例子

    adb push D:\Test1.txt /sdcard/Android/data/
    

    在这里插入图片描述

    • 打印log信息
    adb logcat -v time > pc端日志文件路径
    

    例子

    adb logcat -v time > D:\log.txt
    

    在这里插入图片描述

  • 查看前台应用包名

    #Android 7.0及以下查看前台包应用包名
    adb shell dumpsys activity | find "mFocusedActivity"
    
    #Android 8.0以上 dumpsys activity 的信息已经有变化,用此命令进行查看包名
    adb shell dumpsys activity | find "mResumedActivity"
    

    例子

    在这里插入图片描述

三、android系统日志文件

1.logcat日志文件

  • android日志系统提供了记录和查看系统调试信息的功能,日志都是从各种软件和一些系统的缓冲区中记录下来的,缓冲区可以通过logcat命令来查看和使用

  • 使用方式

    • adb logcat [<option>] … [<fiter-spec>]…
  • 开发者选项,有个选项叫做 “日志记录器缓冲区大小” 默认是256K,日志是循环写入环形缓冲区的。在通常情况下,写满时最旧的们志会被删除以给新输出的日志留内存空间——真机设置,模拟器一般没有

    在这里插入图片描述

    在这里插入图片描述

2.logcat日志文件分析

  • 输出的日志格式如下所示:

    在这里插入图片描述

  • 由五部分组成:

    • 1.写下日志时的时间,如图中 12-02 23:02:31.289。

    • 2.优先级,在Android中,日志的优先级从低到高分以下几种:

      • V——Verbose(最低级别,开发调试中的一些详细信息,仅在开发中使用,不可在发布产品中输出)
      • D——Debug(调试,用于调试的信息,可以在发布产品中关闭,比较常见)
      • I——Info(信息,一般提示性的消息)
      • W——Warning(警告))
      • E——Error(错误,已经出现可影响运行的错误,比如应用crash时输出的日志)
    • 3.标签(tag),标明日志发起者和方便日志的过滤筛选,如图中MiuiNetworkPolicy,类和模块

    • 4.PID(进程ID),如图中1591

    • 5.正文:本日志的主体内容

四、分析crash & ANR 日志

1.发生crash如何分析

在这里插入图片描述

  • 发生crash,adb logcat获取日志分析:
    • 1.搜索exception关键字,根据时间,包名定位
    • 2.搜索fatal / caused by关键字
    • 3.搜索force finish

找到对应的日志,贴到bug里,发给开发! ! !

2.发生ANR如何分析

在这里插入图片描述

何为ANR

ANR全名Application Not Responding,也就是应用无响应,当操作在一段时间内系统无法处理时,系统层面会弹出如图所示那样的ANR对话框

  • 用户在主线程长时间被阻塞时提供处理交互,提高用户体验

  • Android系统一种自身检测机制

  • 系统发生ANR时,会通过三种方式记录信息:

    • 1.Logcat日志(通过Logcat日志进行分析)
      • 日志格式
        • ActivityManager:ANR in [进程名] ([部件名])
        • ActivityManager:PID:[应用进程ID]
        • ActivityManager:Reason:[原因提示] [Process CPU state]
        • 通过搜索anr关键字,若无具体java报错信息,继续另一种方法获取日志
        • 通过logcat日志文件搜索ANR查看的日志信息,只能辅助定位问题。无法具体知道因为什么原因导致的
    • 2.Trace文件(通过Trace文件进行分析)
      • 文件路径:/data/anr/
      • Dump stack trace信息
      • Dump 的进程包括:当前应用进程,父进程,主进程,persistent进程,以及CPU占用率排在前几位的(最多5个)进程
      • ps:只能记录最后一次发生的anr的信息
    • 3.DropBox服务
      • 通过dropbox可以收集系统一段时间内的异常信息(包括ANR、crash)
      • /data/system/dropbox是dropbox指定的文件存放位置

总结

以上都是基于Android实现的

扩展(IOS app定位日志)

  • MacOS电脑:xcode工具 —— 一出现问题,把手机直接给ios开发
  • Windows:iTunes、iTools
  • 使用工具将日志同步到电脑,然后贴到bug你给开发!

相关文章:

App测试之App日志收集及adb常用命令

文章目录 前言一、adb是什么1.APP测试收集手机日志常用的工具2.adb下载与安装3.ADT/SDK/ADB是什么4.adb连接真机 二、adb常用命令三、android系统日志文件1.logcat日志文件2.logcat日志文件分析 四、分析crash & ANR 日志1.发生crash如何分析2.发生ANR如何分析 总结扩展&am…...

【Java面试——并发基础、并发关键字】

3.1 并发基础 Java 并发 - 理论基础Java 并发 - 线程基础 多线程的出现是要解决什么问题的? 本质什么? CPU、内存、I/O 设备的速度是有极大差异的&#xff0c;为了合理利用 CPU 的高性能&#xff0c;平衡这三者的速度差异&#xff0c;计算机体系结构、操作系统、编译程序都…...

如何使用 Java 在Excel中创建下拉列表

下拉列表&#xff08;下拉框&#xff09;可以确保用户仅从预先给定的选项中进行选择&#xff0c;这样不仅能减少数据输入错误&#xff0c;还能节省时间提高效率。在MS Excel中&#xff0c;我们可以通过 “数据验证” 提供的选项来创建下拉列表&#xff0c;但如果要在Java程序中…...

Python安装步骤介绍

本文将介绍Python安装的详细步骤如下&#xff1a; 下载 python安装 python配置环境变量&#xff08;安装时勾选配置环境变量的则无需此步骤&#xff09; 一、python下载 官网&#xff1a;Download Python | Python.org 根据电脑位数下载所需的版本 二、Python安装 1.打开安…...

学习80min快速了解大型语言模型(ChatGPT使用)笔记

学习李宏毅&#xff1a;80min快速了解大型语言模型&#xff08;ChatGPT使用&#xff09;笔记 链接&#xff1a;https://www.youtube.com/watch?vwG8-IUtqu-s 1、创建一个属于自己的GPT 目前&#xff0c;GPT4具备一个功能&#xff0c;Create a GPT。利用这个功能可以创建一个…...

SQL错题集1

1.找出选修课程成绩最差的选课记录 注&#xff1a; 聚合函数只能用在group by和&#xff08;&#xff09;括号中 找最值可用排序order bylimit 1 2. 查询选修成绩 合格的课程 超过2门的 学生编号 3.删除姓名为"LiMing"的学生信息 注&#xff1a; 删除一整行信息&…...

uniapp运行到安卓基座app/img标签不显示

img是html中的标签&#xff0c;他也是一个单标签 image属于服务器控件&#xff0c;是个双标签 问题&#xff1a;uniapp运行到app安卓基座后图片无法显示 原因&#xff1a;自己使用了img标签&#xff0c;而且输入路径无提示&#xff0c;img标签导致图片不显示 解决&#xff…...

vscode非常好用的扩展插件

1、Code Spell Checker&#xff1a; 帮助我们检查单词是否拼写错误&#xff0c;检查规则遵循驼峰拼写法。 2、Color Highlight&#xff1a;高亮显示颜色值 3、Svg Preview&#xff1a; 实时预览svg图片&#xff08;修改width、height、fill等值来实时查看效果&#xff09; 4、…...

一文弄懂BFS【广度优先搜索(Breadth-First Search)】

BFS&#xff0c;全名为广度优先搜索(Breadth-First Search)&#xff0c;是一种用于图或树的遍历或搜索的算法。它的主要思想是由节点自身开始向它的邻居节点新进展开搜索&#xff0c;因此也常被形象地称为“层序遍历”。 BFS 基本思想 BFS 工作原理是&#xff0c;从开始节点开…...

深度学习记录--logistic回归函数的计算图

计算图用于logistic回归函数 先回顾一下单一样本的logistic回归损失函数的公式&#xff0c;公式如下&#xff1a; 将logistic函数用计算图表示出来(以两个基础量为例)&#xff0c;计算图如下&#xff1a; 前向传播已经完成&#xff0c;接下来完成后向传播 运用链式法则依次求…...

Java基本数据类型详解

✨个人主页&#xff1a;全栈程序猿的CSDN博客 &#x1f4a8;系列专栏&#xff1a;Java从入门到精通 ✌座右铭&#xff1a;编码如诗&#xff0c;Bug似流星&#xff0c;持续追求优雅的代码&#xff0c;解决问题如同星辰般自如 Java是一种强类型语言&#xff0c;数据类型在程序中起…...

第十五届蓝桥杯模拟赛(第二期)

大家好&#xff0c;我是晴天学长&#xff0c;本次分享&#xff0c;制作不易&#xff0c;本次题解只用于学习用途&#xff0c;如果有考试需要的小伙伴请考完试再来看题解进行学习&#xff0c;需要的小伙伴可以点赞关注评论一波哦&#xff01;后续会继续更新第三期的。&#x1f4…...

命令模式-C++实现

命令模式是一种行为型设计模式&#xff0c;它将请求封装成一个对象&#xff0c;从而能使你可以用不同的请求对客户端进行参数化。该模式允许请求的发送者和接收者进行解耦&#xff0c;发送者不需要知道接收者的信息&#xff0c;只需要通过命令对象来与它进行交互。 命令模式有…...

3dMax拼图生成工具Puzzle2D使用教程

Puzzle2D for 3dsMax拼图生成工具使用教程 Puzzle2D简介&#xff1a; 2D拼图随机生成器&#xff08;英文&#xff1a;Puzzle2D&#xff09; &#xff0c;是一款由#沐风课堂#用MAXScript脚本语言开发的3dsMax建模小工具&#xff0c;可以随机创建2D可编辑样条线拼图图形。可批量…...

git报错invalid object xxx和unable to read tree xxxxxx

电脑出问题了&#xff0c;导致git仓库像是被损坏了一样&#xff0c;执行git status就会报错unable to read ree&#xff0c;无法正常提交代码至仓库&#xff0c;原因是本地代码仓库.git文件损坏了&#xff0c;无法找到正确的提交历史和路径。 找到了一个解决办法&#xff1a; …...

会泽一村民上山放羊吸烟引发森林火灾,AI科技急需关注

2023年4月&#xff0c;会泽县古城街道厂沟村委会望香台山林中发生了一场由疏忽引发的森林火灾。张某某在放羊时未完全熄灭烟头&#xff0c;导致7.33公顷的林地和草地被焚毁&#xff0c;直接经济损失高达29.097万元。这一事件再次凸显了日常生活中的安全隐患。 在这一背景下&…...

docker-compose部署zabbix+grafana

1.引言 1.1目的 zabbixgrafana实现图形化监控 2.部署环境 服务器ip服务版本192.168.5.137zabbix-server6.0.21192.168.5.137grafana10.2.2192.168.5.152zabbix-client6.0.21 3.部署zabbix-server 3.1 创建zabbix目录 mkdir zabbix3.2 编写docker-compose文件 cd zabbix…...

ios 逆向分分析,某业帮逆向算法(二)

接上讲 上次hook 发现自己的数据有点问题。才发现是自己的编辑器识别出问题了。 上篇sub_1029B6898函数hook数据如下: [iOS Device::作业帮 ]-> arg2: 0 1 2 3 4 5 6 7 8 9 A B C D E F 0123456789ABCDEF 00000000 37 32 65 64 38 31 32 38…...

openCv颜色矩

颜色矩&#xff08;Color Moments&#xff09;是一种常用的图像特征描述方法&#xff0c;用于表示图像中颜色的分布和统计特征。它是基于图像的颜色直方图而计算得到的。 颜色矩通常包括三个维度&#xff1a;平均值、方差和偏度。具体来说&#xff1a; 平均值&#xff08;Mean…...

〖大前端 - 基础入门三大核心之JS篇㊹〗- DOM事件委托

说明&#xff1a;该文属于 大前端全栈架构白宝书专栏&#xff0c;目前阶段免费&#xff0c;如需要项目实战或者是体系化资源&#xff0c;文末名片加V&#xff01;作者&#xff1a;不渴望力量的哈士奇(哈哥)&#xff0c;十余年工作经验, 从事过全栈研发、产品经理等工作&#xf…...

Chapter03-Authentication vulnerabilities

文章目录 1. 身份验证简介1.1 What is authentication1.2 difference between authentication and authorization1.3 身份验证机制失效的原因1.4 身份验证机制失效的影响 2. 基于登录功能的漏洞2.1 密码爆破2.2 用户名枚举2.3 有缺陷的暴力破解防护2.3.1 如果用户登录尝试失败次…...

stm32G473的flash模式是单bank还是双bank?

今天突然有人stm32G473的flash模式是单bank还是双bank&#xff1f;由于时间太久&#xff0c;我真忘记了。搜搜发现&#xff0c;还真有人和我一样。见下面的链接&#xff1a;https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...

【Java学习笔记】Arrays类

Arrays 类 1. 导入包&#xff1a;import java.util.Arrays 2. 常用方法一览表 方法描述Arrays.toString()返回数组的字符串形式Arrays.sort()排序&#xff08;自然排序和定制排序&#xff09;Arrays.binarySearch()通过二分搜索法进行查找&#xff08;前提&#xff1a;数组是…...

《Playwright:微软的自动化测试工具详解》

Playwright 简介:声明内容来自网络&#xff0c;将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具&#xff0c;支持 Chrome、Firefox、Safari 等主流浏览器&#xff0c;提供多语言 API&#xff08;Python、JavaScript、Java、.NET&#xff09;。它的特点包括&a…...

Module Federation 和 Native Federation 的比较

前言 Module Federation 是 Webpack 5 引入的微前端架构方案&#xff0c;允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...

WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)

一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解&#xff0c;适合用作学习或写简历项目背景说明。 &#x1f9e0; 一、概念简介&#xff1a;Solidity 合约开发 Solidity 是一种专门为 以太坊&#xff08;Ethereum&#xff09;平台编写智能合约的高级编…...

Android15默认授权浮窗权限

我们经常有那种需求&#xff0c;客户需要定制的apk集成在ROM中&#xff0c;并且默认授予其【显示在其他应用的上层】权限&#xff0c;也就是我们常说的浮窗权限&#xff0c;那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

MySQL中【正则表达式】用法

MySQL 中正则表达式通过 REGEXP 或 RLIKE 操作符实现&#xff08;两者等价&#xff09;&#xff0c;用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例&#xff1a; 一、基础语法 SELECT column_name FROM table_name WHERE column_name REGEXP pattern; …...

是否存在路径(FIFOBB算法)

题目描述 一个具有 n 个顶点e条边的无向图&#xff0c;该图顶点的编号依次为0到n-1且不存在顶点与自身相连的边。请使用FIFOBB算法编写程序&#xff0c;确定是否存在从顶点 source到顶点 destination的路径。 输入 第一行两个整数&#xff0c;分别表示n 和 e 的值&#xff08;1…...

AI书签管理工具开发全记录(十九):嵌入资源处理

1.前言 &#x1f4dd; 在上一篇文章中&#xff0c;我们完成了书签的导入导出功能。本篇文章我们研究如何处理嵌入资源&#xff0c;方便后续将资源打包到一个可执行文件中。 2.embed介绍 &#x1f3af; Go 1.16 引入了革命性的 embed 包&#xff0c;彻底改变了静态资源管理的…...