7.0 启动app权限弹窗问题

这里提供两种解决方案!

  1.安卓6.0+是可以直接利用uiautomator定位元素点击!这个不细说,定位方式很多种...这个等待时间大家自己定大概两到三秒即可!

    

#安卓6.0+点击方式driver.find_element_by_android_uiautomator(‘new UiSelector().textContains("允许")‘)

  但是一般来说弹窗大多数都是好多个---利用显示等待:启动app之后,在三秒内  没0.5秒寻找一次元素,如果存在则点击,不存在则报错直接pass

  

try:
    while True:
        Element = ("xpath", "//*[contains(@text,‘允许‘)]")
        ac = WebDriverWait(driver, 3, 0.5).until(lambda driver:driver.find_element_by_xpath(‘//*[contains(@text,"允许")]‘))
        ac.click()
except:
    pass

2.还有一种定位方式如下,亲测支持高版本,但是我没有亲自试过是否支持低版本手机的权限弹窗-----因为我不是用的这两种---个人用的方法比较简单粗暴+直接

但是呢,这里建议大家搞个低版本的手机试下,我没测是因为条件不允许,找不到低版本的手机.......希望有朋友测了之后截图留言一波,让我有个底....

try:
    while True:
        Element = ("xpath", "//*[contains(@text,‘允许‘)]")
        ac = WebDriverWait(driver, 1, 0.5).until(EC.presence_of_element_located(Element))
        ac.click()
except:
    pass
    • 然后手动给每台手机安装一遍app,并用记事本获其他玩意记下设备名称
    • 打开app,准备好uiautomatorview(sdk目录下那个定位元素的玩意..),如下图所示记住这个坐标,如:

      admin_lists={‘2905bdb6‘:[360,1149],‘xxxx‘:[1,1]},如果定位不到【允许】这个坐标,就手动点一下允许,按照不动,你会发现在屏幕最上面有一个坐标DX:--/DY:--,记下这个坐标也是一样的!

        

admin_list={‘2905bdb6‘:[(360,1149)],‘xxxx‘:[(1,1)]}
for a in admin_list:
    deviceList=‘‘.join(os.popen(‘adb devices‘).readlines())
    Device=re.findall(r"(.+?)\t",deviceList)[0]
    print(Device)
    if a==Device:
        driver.tap(admin_list[a])

      

      原理就是先把我们测试机弹出权限允许的那个坐标给记录下来,第一次安装启动的时候查询一下设备名称然后取到坐标,然后点击---这个方法也是适合多设备

方法有点捞,但是实用靠谱---另外这里不要想着去适配屏幕,这个不存在的,据我了解不同手机的弹窗样式可能是不一样的..

如果只弹出一个-直接用上面的方法就可以了,但是如果权限弹窗有多个呢:

加个方法就可以了---有多个的话,这个就得根据自己的app调试了...但是大同小异

如下所示:

admin_list={‘2905bdb6‘:[(360,1149)],‘xxxx‘:[(1,1)]}
for a in admin_list:
    deviceList=‘‘.join(os.popen(‘adb devices‘).readlines())
    Device=re.findall(r"(.+?)\t",deviceList)[0]
    print(Device)
    if a==Device:
        for i  in range(5):
            driver.tap(admin_list[a])
            time.sleep(3)

  

具体应该还有很多骚方法--大家可以自己研究一下,只要能实现就可以,我个人方面对于执行效率并没有太过--(想不到词了)

这章有一定的python语法:

循环、正则、os、range、readlines、dict取值----如果这个不太懂得-建议看下 廖雪峰的python3教程---直接百度廖雪峰就可以了

原文地址:https://www.cnblogs.com/pythontest/p/9495928.html

时间: 2024-10-08 23:22:39

7.0 启动app权限弹窗问题的相关文章

appium+python自动化47-首次打开app权限弹窗问题

前言 用真机运行appium代码,首次打开app有的手机会出现权限弹窗问题,一般这种弹窗都是在引导页前面或者引导页后面出现.权限弹窗上面的按钮都是固定的,只需要定位到"始终允许"按钮,点击确定就可以了.还有一个问题是这种弹窗的个数不确定,有的app是2个有的是3个,为了解决这个问题,可以专门写个判断方法.注意:模拟器是不会有这种权限弹窗的 环境:appium 1.8android 7.0美团app 权限弹窗 1.以美团app为案例,安装app首次启动的时候,在引导页出现权限弹出框,如下

【Android开发日记】初次探秘Android Service!Service开机启动+重力感应+弹窗+保持运行

前言: 最近在写一个小程序,需求是手机摇一摇就弹窗出来.第一次使用了Service,学习了两天,实现了Service弹窗,开机启动,Activity启动和销毁.满足了自己的需求.现记录学习心得.希望能给你带来一些帮助. 1.Service创建:重写4个方法 onBind():返回一个IBinder对象,这个对象可以使应用程序与Service通信.如果用startService.stopService启动和关闭Service的话,Service和访问者是无法通信交换数据的.onBind()返回值设

Android 6.0+ 运行时权限

1.权限被分为了普通和危险两种 2.打电话的Demo import android.Manifest; import android.app.Activity; import android.content.Intent; import android.content.pm.PackageManager; import android.net.Uri; import android.os.Bundle; import android.provider.Settings; import andro

Android 6.0 运行时权限管理

android 6.0 对权限进行了严格的管理 新的权限策略讲权限分为两类,第一类是不涉及用户隐私的,只需要在Manifest中声明即可,比如网络.蓝牙.NFC等:第二类是涉及到用户隐私信息的,需要用户授权后才可使用,比如SD卡读写.联系人.短信读写等. Normal Permissions 此类权限都是正常保护的权限,只需要在AndroidManifest.xml中简单声明这些权限即可,安装即授权,不需要每次使用时都检查权限,而且用户不能取消以上授权,除非用户卸载App. ACCESS_LOC

谈谈Android 6.0运行时权限理解

前言 谷歌在2015年8月份时候,发布了Android 6.0版本,代号叫做“棉花糖”(Marshmallow ),其中的很大的一部分变化,是在用户权限授权上,或许是感觉之前默认授权的不合理,现在6.0出来,使得用户权限授权变得合理.这可能也是参考IOS系统的,只有在用户需要使用权限的时候,才去授权请求,这样做的目的是提高用户体验,当然,用户感觉好了,受苦的是我们开发人员,原来的规则不适用了,现在我们去适应新的规则,毕竟是靠谷歌这颗大树吃饭的嘛. 原来权限模型 在Android 6.0版本之前,

Android6.0运行时权限(基于RxPermission开源库)

版权声明:本文为博主原创文章,未经博主允许不得转载. 前言 在6.0以前的系统,都是权限一刀切的处理方式,只要用户安装,Manifest申请的权限都会被赋予,并且安装后权限也撤销不了. Android 6.0 采用新的权限模型,只有在需要权限的时候,才告知用户是否授权:是在runtime时候授权,而不是在原来安装的时候 ,同时默认情况下每次在运行时打开页面时候,需要先检查是否有所需要的权限申请. 判断是否是需要运行时权限的标记就是targetSDKVersion. 当targetSDKVersi

Android 6.0 运行时权限管理最佳实践

Android 6.0 运行时权限管理最佳实践 版权声明:转载必须注明本文转自严振杰的博客: http://blog.yanzhenjie.com 这是一篇迟来的博客,Android M已经发布一年多了(6.0的变化),在Android M中权限系统被重新设计,发生了颠覆性的变化,很多人把握不好这个变化,一是对这个权限策略和套路还没有摸透,二是没有一个很好的实践来支撑,在我的技术开发群里很多人问我关于权限的问题,往往我都没有直接回答,因为这个问题不是一两句说的清楚的,这几点是今天我写这篇博客的原

谈谈Android 6.0 的动态权限管理

1.前言 大家都知道Android 6.0的新特性之一就是应用权限的管理.也就是说凡是涉及用户隐私的权限,用户可以自己去设置管理了.然而在6.0以前,我们安装一款APP是默认同意此APP所需的所有权限(比如定位.访问通讯录),不同意就不能安装.当然,国内的一些手机厂商基于Android定制的系统中,可以实现在6.0以前关闭指定的权限.如下图: 2.危险权限列表(Dangerous Permission) Dangerous Permission一般都是涉及用户隐私的权限. 从上面的图片中可以看到

Android 6.0 运行时权限处理完全解析

一.概述 随着Android 6.0发布以及普及,我们开发者所要应对的主要就是新版本SDK带来的一些变化,首先关注的就是权限机制的变化.对于6.0的几个主要的变化,查看查看官网的这篇文章http://developer.android.com/intl/zh-cn/about/versions/marshmallow/android-6.0-changes.html,其中当然包含Runtime Permissions. ok,本篇文章目的之一就是对运行时权限处理的一个介绍,以及对目前权限相关的库