news 2026/4/15 22:07:01

web自动化测试窗口框架与验证码登录处理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
web自动化测试窗口框架与验证码登录处理
前言

selenium的作用域切换
selenium在处理元素时遇见新窗口、网页嵌套网页、网页的原生弹窗,无法进行直接处理作用域里元素的内容,需要通过切换作用域来处理此类问题。

selenium三种作用域切换:
①、window窗口切换
②、iframe切换
③、alert弹窗切换

window窗口切换

以百度为例,在原百度的网页上,点击超链接后会打开一个新的网页,这个时候如果需要定位新的网页上的元素,就需要切换作用域了。

切换作用域实现方案:

使用driver.window_handles,可以获取全部网页的索引,并且将索引存放于一个数组中,因此可以通过数组取值的方式实现切换网页作用域:

driver.switch_to.window(driver.window_handles[-1])

切换作用域后,原网页上就无法进行元素定位了,可以通过数组下标取值的方式,将作用域切换为原网页:

driver.switch_to.window(driver.window_handles[0])

代码实现:

from selenium import webdriver #打开浏览器 driver = webdriver.Chrome("chromedriver.exe") driver.maximize_window() #打开网页 driver.get("https://www.baidu.com/") driver.find_element_by_link_text("hao123").click() #会跳转一个新的hao123的窗口,此时就无法操作原百度网页的窗口了,因此需要切换作用域 #获取所有网页的索引:driver.window_handles # print(driver.window_handles) #打印出来的值是一个数组:['37554D9C36A0A691571C87C250434881', '860CA08A7CEEB72959449FCB3B75D146'],因此可以通过数组取值的方式实现切换网页作用域 driver.switch_to.window(driver.window_handles[-1]) #把driver切换到最新弹出来的窗口 print(driver.title) #获取当前网页的标题 driver.find_element_by_xpath('//*[@id="search"]/form/div[2]/input').send_keys("csdn")

iframe切换

在某些后台管理系统中,网页中嵌套小网页,这种情况是没有办法直接处理小网页的,大网页的内容是可以直接处理的

识别小网页
怎么查看哪些页面是嵌套小网页的:iframe通常在大网页中是以iframe标签存在的,标签里面也会有html的标签。我们可以通过源代码或者右键空白区域去判断是否存在【重新加载框架选项】:

①源代码查看标签判断:定位元素后,去代码前后找是否有iframe标签,且里面还有html标签

②右键空白区域查看是否存在【重新加载框架选项】判断:

切换作用域
先找到iframe标签的id值,然后定位元素,再使用driver.switch_to.frame()方法切换。相同的道理,切换作用域后,原网页就无法进行元素的定位,可将作用域切换回原网页:driver.switch_to.default_content()

代码实现:

from selenium import webdriver driver = webdriver.Chrome("chromedriver.exe") driver.maximize_window() driver.get("https://passport2.eastmoney.com/pub/login") #作用域从大网页切换到小网页(不同版本的selenium有以下两种写法) driver.switch_to.frame(driver.find_element_by_id('frame_login') ) #frame_login为frame标签的id值 driver.switch_to.frame("frame_login") #输入框的xpath://*[@id="txt_mobile"] driver.find_element_by_xpath('//*[@id="txt_mobile"]').send_keys("110") #把作用域从小网页切换到大网页(不同版本的selenium有以下两种写法) driver.switch_to.default_content() driver.switch_to.parent_frame() #/html/body/div[1]/div/div/h1 e = driver.find_element_by_xpath('/html/body/div[1]/div/div/h1') print(e.text) #能成功打印,说明小网页切换大网页成功了

alert弹窗切换

alert窗口就是js提示框,它是浏览器原声的弹窗,不属于web界面,所以,在有这个提示框的作用下,我们是无法继续web操作的,必须先处理掉js弹窗,才可以继续。

Alert类提供了四个方法来处理弹窗:

driver.switch_to.alert.accept() # 确定操作 driver.switch_to.alert.dismiss() # 取消操作 driver.switch_to.alert.send_keys("") # alert弹框输入文本 driver.switch_to.alert.text() # 获取alert的文本内容

代码实现:

from selenium import webdriver import time #打开浏览器,获得浏览器句柄 driver = webdriver.Chrome("chromedriver.exe") driver.maximize_window() driver.get("http://localhost:8080/selenium/selenium6.html") #xpath:/html/body/a driver.find_element_by_xpath('/html/body/a').click() time.sleep(10) #等待10s查看弹窗关闭效果 driver.switch_to.alert.accept() # 确定操作 driver.switch_to.alert.dismiss() # 取消操作 driver.switch_to.alert.send_keys("") # alert弹框输入文本 driver.switch_to.alert.text() # 获取alert的文本内容

登录验证

在做自动化测试时,有些图形化的验证码很复杂,验证码的作用是为了防止自动化工具,可以有以下几种方式去处理它:

万能码
深度学习
使用cookie绕过登录

服务器验证用户身份的方式有两种:第一种是使用cookie和session的方式;第二种是使用token的方式。

第一种验证方式下,我们可以使用已经登录账号的cookie,来伪造账号已经登录了

cookie理解

比如用户登录了某个网站后,再次刷新这个页面去请求服务器,如果没有相关机制的话,服务器是不知道这个请求是否还是刷新之前登录的用户发出来的。此时,为了维持用户的登录状态,即为了使服务器能够识别页面刷新之后的请求,就可以使用cookie机制。

用户A第一次请求服务器后,服务器会自动生成一个暗号,并将这个暗号的一部分返回给用户A,用户A将其以cookie的方式存起来,下次再次访问的时候,会自动把cookie带上,服务器拿到cookie后将其与自己的进行比对,识别出是用户A(以此类推,不同的用户有不同的暗号),服务器通过这种方式以此来识别各个用户。

为什么要这样做:请求时用的是http协议,http协议有一个特点就是:无状态,即服务器在每次请求时,他不知道谁是谁,为了解决这个问题,就诞生了cookie和session机制。在服务器上以session的形式存在,用户端以cookie的形式存在。

例如用户A已经登录,在服务器上对应的session就会是登录状态,用户A再次请求,服务器就不会让用户A再进行以此登录操作了。所以,cookie绕过登录其实是登录状态保持,而不是真的不需要登录

cookie只是一个暗号,所有的登录记录都是存在session里

使用cookie绕过登录的实现
①第一步:获取已经登录的cookie

from selenium import webdriver import time driver = webdriver.Chrome("chromedriver.exe") driver.maximize_window() driver.get("https://www.bilibili.com/") #第一步:获取已经登录的cookie(手工抓取) time.sleep(60) #等待的时间用于手动登录 print(driver.get_cookies())

②第二步:手动添加已经登录的cookie(在添加之前需要将原有的cookie删掉)

由于Selenium每次启动的浏览器是一个隔离的环境,不能直接使用本地已经保存的Cookies值,我们需要通过driver的add_cookie()方法手动添加Cookies

#第二步:手动添加已经登录的cookie(在添加之前需要将原有的cookie删掉) driver.delete_all_cookies() #下面是刚才获取的cookie,是以数组形式存在的,可遍历添加cookie cookies = [{"xxxxx"}] for cookie in cookies: driver.add_cookie(cookie)

③、第三步:刷新网页

  1. #刷新网页

  2. driver.refresh()

最后作为一位过来人也是希望大家少走一些弯路,在这里我给大家分享一些软件测试的学习资料和我花了3个月整理的软件测试自学全栈,这些资料希望能给你前进的路上带来帮助。

视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/11 2:43:17

解锁B2B品牌成功密码:SWOT分析全攻略

在商业的风云变幻中,许多企业开局顺利,却在发展途中陷入困境,不知问题出在哪里。其实,很多企业失败的原因在于忽视自身优劣势、错过发展机遇。而SWOT分析,正是帮助企业拨开迷雾、制定有效策略的关键工具。一、揭开SWOT…

作者头像 李华
网站建设 2026/4/16 10:58:00

【Linux命令大全】003.文档编辑之nl命令(实操篇)

【Linux命令大全】003.文档编辑之nl命令(实操篇) ✨ 本文为Linux系统文档编辑与文本处理命令的全面汇总与深度优化,结合图标、结构化排版与实用技巧,专为高级用户和系统管理员打造。 (关注不迷路哈!!&#…

作者头像 李华
网站建设 2026/4/12 4:50:35

大模型后训练

什么场景需要后训练 1. 若仅需模型遵循少量指令(如回避敏感话题或禁止公司间比较),通过提示工程即可实现,但该方法虽简单却不够稳定 2. 如需查询实时数据库,检索增强生成或基于搜索的方法可能更适用 3. 创建领域专用…

作者头像 李华
网站建设 2026/4/16 11:00:25

AI编程:程序员的职业新选择

AI编程:程序员的职业新选择 关键词:AI编程、程序员职业、人工智能、编程技术、职业发展 摘要:本文深入探讨了AI编程作为程序员职业新选择的相关内容。从背景介绍入手,阐述了目的、预期读者、文档结构和术语等。详细解析了AI编程的核心概念与联系,包括原理和架构的示意图及…

作者头像 李华
网站建设 2026/4/11 2:53:13

springboot+vue开发的Easy云盘网盘文件共享系统应用和研究

文章目录摘要关键词项目简介大数据系统开发流程主要运用技术介绍爬虫核心代码展示结论源码文档获取定制开发/同行可拿货,招校园代理 :文章底部获取博主联系方式!摘要 Easy云盘是一款基于SpringBoot和Vue技术栈开发的网盘文件共享系统,旨在为…

作者头像 李华
网站建设 2026/4/10 22:14:56

4种方法解除ZIP压缩文件的密码保护

为了方便储存或者传输文件,我们经常会把文件转换成ZIP压缩文件,想保密性好的话,还会添加打开密码。 那如果后续不需要打开密码了,或者一个不小心忘记了密码,该怎么清除密码呢? 下面会根据不同情况说下具体如…

作者头像 李华