『与善仁』Appium基础 — 19、元素定位工具(三)
APP中的元素定位工具大致有三种:
uiautomatorviewer
工具Appium Inspector
工具Chrome Inspect
工具
提示:本篇文章介绍
Chrome Inspect
工具。
1、Chrome Inspect介绍
Chrome Inspect
定位工具是用来抓取APP中Webview页面的。
为了项目的需求,为了更好的保证效果和布局跨平台,Android&H5混合开发一般是我们不错的选择。Google浏览器中的Chrome Inspect
定位工具,提供了一个移动端Web页面开发调试的功能,通过它我们可以调试手机页面,可以看到页面的源码,从而进行元素的定位。
使用Chrome Inspect
定位工具的前提条件
使用Chrome开发人员工具调试原生Android应用中的WebView,Android版本应该在Android4.4(KitKat)或更高版本上,通过DevTools在原生Android应用中调试WebView页面中的内容。
2、Chrome Inspect打开方式
打开PC端的Chrome浏览器,在访问地址栏中输入chrome://inspect/
就可以了,就是这么简单。
如下图:
3、Chrome Inspect工具的使用
(1)Chrome Inspect工作前提
- 所测试设备是开机状态(手机或者模拟器)。
- 确保电脑与设备是链接状态,也就是
cmd进入命令行终端,
输入adb connect 127.0.0.1:21503
链接逍遥模拟器,
输入adb devices
能够获取设备名称。
(2)Chrome Inspect操作
1)在APP中打开含有Webview的页面
例如:开百度APP,进入到微博登陆的界面就是一个含有Webview的页面。
如下图:
2)在Chrome Inspect
中识别到Webview页面
我们进入到PC端的Chrome浏览器中,访问地址栏中输入chrome://inspect/
(没有显示的话就点击一下刷新),就可以检测到当前应用程序界面是Webview页面了。
如下图:
3)点击inspect可以进入调试视图
点击如上图中的inspect
,可以进入Chrome Inspect
工具的调试视图 .
会弹出一个新窗口,显示当前页面的Webview元素信息。
并且元素定位方法同Selenium WebDriver一致。
就是这么简单。
4、使用Chrome Inspect遇到的问题
(1)Android系统版本问题
Android移动设备版本应该在Android4.4或更高版本上。
从Android 4.4开始,webkit
是支持远程调试的。
(2)所测App的debug模式要打开
在使用Chrome Inspect
工具调试移动端APP的Webview页面的时候,需要将该APP的debug模式打开。
但其实大部分APP的debug模式都是关闭的,要去找一个开启debug模式的版本还是比较麻烦的。
因此需要使用借助第三方工具来强制开启任何APP的Android webview debug
模式,使之可以使用Chrome Inspec
t。
而这个工具就是Xposed
。
(3)Xposed工具的安装
1)将设备进行root。
因为涉及到root
权限,因此需要将设备进行root
。
有很多工具可以来root
,比如KingRoot
等。
注:Android模拟器默认root。
2)下载Xposed
框架。
官方下载地址:http://repo.xposed.info/module/de.robv.android.xposed.installer
点击页面下方的Show older versions
,选择一个稳定版本进行下载。
3)安装Xposed
框架。
将下载好的Xposed
安装包de.robv.android.xposed.installer_v32_de4f0d.apk
,直接拖入到Android模拟器中,进行安装。
安装好后如下图:
4)安装/更新Xposed
框架。
打开Xposed Installer
,选择“安装/更新”的最新版,然后点“安装”会自动下载刷入。(过程可能会有一些慢)
如下图所示:
安装界面,如下图所示:
安装更新完成后的界面,如下图所示:
4、安装Xposed webview debugging
模块。
打开Xposed
界面中点击左上角的三条横杠,选择模块,然后启用需激活模块的复选框,正常重启后即可使用。
如下图所示:
如果你的手机中没有安装WebViewDebugHook
模块或者没有任何模块,如下图:
可以在Xposed
中进行下载安装WebViewDebugHook
模块。
如下图所示:
然后按照上面的方式激活WebViewDebugHook
模块即可。
(4)HTTP/1.1 404 Not Found和空白页问题
在chrome://inspect/#devices
中点击inspect
出现的窗口中,界面是出现HTTP/1.1 404 Not Found
或者是空白页的现象。
空白页,如下图所示:
HTTP/1.1 404 Not Found
界面,如下图所示:
原因:
对于国内的程序猿来说,由于无法访问 https://chrome-devtools-frontend.appspot.com,就会出现出现HTTP/1.1 404 Not Found
或者空白页面的现象。
例如上面的@33f6ad690e178169a17596eeec8596751a696d1e
就是移动设备中浏览器的一个版本号,当你换一个手机或模拟器的时候,版本号可能就不一样了。
因为不同型号的手机生产商可能会打包不同版本的Chrome浏览器内核,Chrome Inspect
定位工具就会先访问 https://chrome-devtools-frontend.appspot.com,下载对应的chrome-devtools
相关驱动,而国内无法访问并下载这些驱动,就出现了404和空白页。
网上找到如下三种解决方式:
- 方法一:下载
devtools
的inspect
的 离线开发者调试工具包。(花钱,没有免费的) - 方法二: 修改网络连接,修改hosts文件。
- 方法三:使用第三方的
chromium
内核的浏览器,如QQ浏览器。
(都不好使,大家也可以自己试试)
推荐使用VPN,或者下载一个可FQ的谷歌浏览器用一下即可,不用的时候就关了。
(5)补充:安卓模拟器打开开发者选项
- 打开手机的“设置”,进入到“设置”页面;
- 滑到“设置”页面的最下端,找到“关于手机”,进入到“关于手机”页面;
- 找到“版本号”,连续点击。
- 会弹出一段文字提醒,直到提醒次数为0后,结束点击。
- 返回“设置”界面,开发者选项就出来了。
『与善仁』Appium基础 — 19、元素定位工具(三)的更多相关文章
- 『与善仁』Appium基础 — 17、元素定位工具(一)
目录 1.uiautomatorviewer介绍 2.uiautomatorviewer工具打开方式 3.uiautomatorviewer布局介绍 4.uiautomatorviewer工具的使用 ...
- 『与善仁』Appium基础 — 18、元素定位工具(二)
目录 1.Appium Inspector介绍 2.Appium Inspector打开方式 3.Appium Inspector布局介绍 4.Appium Inspector工具的配置 5.Appi ...
- 『与善仁』Appium基础 — 20、Appium元素定位
目录 1.by_id定位 2.by_name定位 3.by_class_name定位 4.by_xpath定位 5.by_accessibility_id定位 6.by_android_uiautom ...
- 『与善仁』Appium基础 — 27、模拟手势点击坐标
目录 1.模拟手势点击坐标 2.tap()用法 3.练习 4.弊端 1.模拟手势点击坐标 在定位元素的时候,你使出了十八班武艺还是定位不到,怎么办呢?(面试经常会问) 那就拿出绝招:点击元素所在位置的 ...
- 『与善仁』Appium基础 — 28、webview的操作方式
目录 1.先了解什么是Hybrid(混合) 2.识别Webview 3.context上下文 4.Webview和原生页面之前的切换 5.综合练习 我们之前说过的所有操作,都是对原生页面的操作. 在手 ...
- 『与善仁』Appium基础 — 12、Appium的安装详解
目录 (一)Appium server安装 方式一:(桌面方式:推荐) 1.Appium Desktop下载 2.Appium Desktop安装 3.Appium Desktop使用 方式二:(No ...
- 『与善仁』Appium基础 — 22、获取元素信息的操作(一)
目录 1.获取元素文本内容 (1)text()方法 (2)get_attribute()方法 (3)综合练习 2.获取元素在屏幕上的坐标 1.获取元素文本内容 (1)text()方法 业务场景: 进入 ...
- 『与善仁』Appium基础 — 23、操作滑动的方式
目录 1.swipe滑动 2.scroll滑动 3.drag拖拽事件 4.滑动方法小结 5.拓展:多次滑动 6.综合练习 在Appium中提供了三种滑动的方式,swipe滑动.scroll滑动.dra ...
- 『与善仁』Appium基础 — 25、APP模拟手势高级操作
目录 1.手指轻敲操作 2.手指按下和抬起操作 3.等待操作 4.手指长按操作 5.手指移动操作 6.综合练习 APP模拟手势的动作都被封装在TouchAction类中,TouchAction是App ...
随机推荐
- Balance的数学思想构造辅助函数
本类题的证明难点便在于如何构造出满足答案的辅助函数.通过下列类题便可以很好的理解. 题一 该类题可以理解为积分内部f(x)与xf(x)处于一种失衡状态,故我们需要使其平衡,否则直接构造出的函数无法满足 ...
- 洛谷 P4774 [NOI2018] 屠龙勇士
链接:P4774 前言: 交了18遍最后发现是多组数据没清空/ll 题意: 其实就是个扩中. 分析过程: 首先发现根据题目描述的选择剑的方式,每条龙对应的剑都是固定的,有查询前驱,后继(在该数不存在前 ...
- 访问单个结点的删除 牛客网 程序员面试金典 C++ Python
访问单个结点的删除 牛客网 程序员面试金典 C++ Python 题目描述 实现一个算法,删除单向链表中间的某个结点,假定你只能访问该结点. 给定待删除的节点,请执行删除操作,若该节点为尾节点,返回f ...
- 【Go语言学习笔记】Go语言的基础语法
上一篇已经说了,Go的语法和C的很接近,直接看看异同即可. 变量 变量名还是一样,字母或下划线开头,区分大小写.不能是关键字. Go定义了int32和int64这种类型来显示声明大小,和C里面的sho ...
- k8s入坑之路(7)kubernetes设计精髓List/Watch机制和Informer模块详解
1.list-watch是什么 List-watch 是 K8S 统一的异步消息处理机制,保证了消息的实时性,可靠性,顺序性,性能等等,为声明式风格的API 奠定了良好的基础,它是优雅的通信方式,是 ...
- HydroD:辅助脚本函数
HydroD:辅助函数 在HydroD中,使用JS脚本可以快速进行模拟参数设置,但是经过尝试,HydroD中的JS脚本语言并不支持现在JavaScript中的一些语法.所以考虑采用Matlab字符串拼 ...
- 【解决方案】Pyinstaller打包exe策略(简单实用)
场景说明 在业务场景中, 经常需要Python开发一些小程序/脚本/GUI界面,进行简单的项目测试或未安装Python 的小伙伴们使用. 使用Pyinstaller将Python脚本或者项目打包,生成 ...
- Gson gson = new GsonBuilder().setDateFormat("yyyy-MM-dd HH:mm:ss").create()
在Java中处理JSON格式的数据时,Google Gson 是个不错的选择,用起来挺方便的,也有一定灵活性.我现在工作中在参与的两个项目里都有用它.不过它在处理Date格式时有个小陷阱,在不同环境 ...
- 动态代理中newProxyInstance中三个参数
JDK Proxy(代理对象): Proxy.newProxyInstance 方法的三个参数创建代理对象 增强 person对象 使用代理对象代替person 去执行 doCourt方法参数1 类 ...
- [第三章]c++学习笔记1(this指针)
this指针作用,其作用就是指向成员函数所作用的对象 使用例 为了返回c1,使用this指针,来指向作用的对象 使用空指针调用hello,调用hello欲使其作用在p指向的对象上,然而p没指向任何对象 ...