曲鸟全栈UI自动化教学(四):Selenium工作原理及Webdriver对浏览器的配置和操作

简介: 曲鸟全栈UI自动化教学(四):Selenium工作原理及Webdriver对浏览器的配置和操作

一、前言


上篇文章我们学习了Selenium页面操作原理及如何高效的进行元素定位

Selenium的工作原理又是什么?是如何驱动浏览器的呢?这篇文章为你讲解Selenium工作原理及Webdriver对浏览器的配置和操作。


二、Selenium工作原理


Selenium进行自动化测试主要依赖三项:


测试脚本(你写的代码)

浏览器驱动(Webdriver,比如:chromedriver)

浏览器

其中核心部分就是Webdriver,它提供了一系列的API来供我们使用,以至于驱动浏览器做一些操作。

它的工作原理有时也会作为面试题,不少小伙伴Selenium用的很熟练,但因为答不出它的工作原理而被Pass!

所以我简单总结了一下,为了面试不被pass的标准答案


Webdriver工作原理:


webdriver用于通信用户编写的代码和浏览器。

当使用类似webdriver.Chrome()启动浏览器后,webdriver会将启动的浏览器绑定到特定的端口,并作为服务端 (类似前后端分离项目的后端)


客户端 (用户编写的代码),通过ComandExecutor发送HTTP请求给服务端

服务端通过WebService将其翻译为浏览器读的懂的脚本传给浏览器进行执行,执行完成后,浏览器把执行结果返回给WebService,WebService再把返回的结果做一些封装,然后返回给客户端。


91eb897c51344ffea18485c4bb03e5cc.png


三、Webdriver常用配置


1. 启动浏览器


通过查看Selnium->webdriver文件夹,发现Selnium支持6种浏览器:

chromeedgefirefoxieoperasafari


83a1d1258c874681b4be9b484f162f9d.png


这里用谷歌、火狐的启动来举例


  1. 启动谷歌浏览器(需要chromedriver)


from selenium import webdriver
browser = webdriver.Chrome()


  1. 启动火狐浏览器(需要geckodriver)


from selenium import webdriver
browser = webdriver.Firefox()



2. Webdriver配置项


webdriver有很多配置项,例如设置请求头、隐藏浏览器运行、配置Webdriver路径等;下面为你介绍常用的配置项:


2.1 首先调用对应的配置类(以chrome举例)


chrome_options = webdriver.ChromeOptions()


2.2 最大化浏览器窗口


chrome_options.add_argument('--start-maximized')


2.3 隐藏浏览器运行(无界面Linux时,不加这条会报错)


chrome_options.add_argument('--headless')


2.4 给予root执行权限(Linux上运行时需要)


chrome_options.add_argument('--no-sandbox')


2.5 不加载图片,提升速度


chrome_options.add_argument('blink-settings=imagesEnabled=false')


2.6 使用已打开的浏览器


以chrome浏览器举例,我们可以通过【cmd】在chrome所在目录执行命令:

chrome.exe --remote-debugging-port=9222 --user-data-dir="C:\selenum\AutomationProfile"

-remote-debugging-port:用于配置浏览器启动占用的端口,可以指定任何未被占用的端口

-user-data-dir:指定创建新Chrome配置文件的目录;它是为了确保在单独的配置文件中启动chrome,不会污染你的默认配置文件。


然后在代码中加入下面的配置即可使用刚刚打开的浏览器了

chrome_options.add_experimental_option("debuggerAddress", "127.0.0.1:9222")

这样做的好处是:


  1. 是一个由chrome启动的浏览器,不容易被所测网站检测出是自动化程序、有利于爬虫的过检测。
  2. 基于该运行浏览器所产生的缓存、cookie等数据都会被记录。下次启动的时候不用重新登录帐号,也不用因为没有缓存导致页面加载时间过长。


2.7 手动指定浏览器位置


当存在多个谷歌浏览器或谷歌浏览器环境异常时,可以指定其浏览器文件路径进行驱动

chrome_options.binary_location = r"C:\Program Files (x86)\Google\Chrome\Application\chrome.exe"


2.8 隐藏【受到自动化测试软件的控制】提示

9e78a0bbee1a4bf19a65765f13e5888f.png


通过该配置项可以隐藏上图的提示


chrome_options.add_experimental_option('excludeSwitches', ['enable-automation'])


2.9 指定浏览器大小


下面的代码会启动一个宽100,长1000的浏览器


chrome_options.add_argument(f'--window-size={100},{1000}')


2.10 指定浏览器位置


下面的代码会启动一个左边距为100,上边距为200的浏览器


chrome_options.add_argument(f'--window-position={100},{200}')


2.11 指定浏览器启动语言


有时候开启浏览器需要特别的语言版本,如果未进行配置则启动的是系统语言对应的浏览器,我们的被测网站如果是英文的,但系统是中文的,开启的浏览器就是中文的,提交的某些数据按照zh_CN.UTF-8的格式提交了,导致数据报错,那么我们就需要设置浏览器启动语言。

chrome_options.add_argument('lang=en-us')


2.12 更换浏览器请求头


有时候需要模拟手机访问某些页面的时候,可以通过配置user-agent项来实现

下面的代码会将浏览器模拟为安卓手机访问

user_ag = 'MQQBrowser/26 Mozilla/5.0 (Linux; U; Android 7.3.7; zh-cn; MB200 Build/GRJ22;CyanogenMod-7) ' \
              'AppleWebKit/533.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1 '
chrome_options.add_argument('user-agent=%s' % user_agent)

执行效果

e140f26d71544d3fbe5713e960796b14.png

2.13 设置浏览器代理


chrome_options.add_argument('--proxy-server=你的代理ip地址')


2.14 使用配置


下面的代码会【最大化窗口】且【不加载图片】的启动一个浏览器:


from selenium import webdriver
chrome_options = webdriver.ChromeOptions()
chrome_options.add_argument('--start-maximized')
chrome_options.add_argument('blink-settings=imagesEnabled=false')
browser = webdriver.Chrome(options=chrome_options)


3. Webdriver常用操作


3.1 获取浏览器名称


browser.name


3.2 最大化浏览器窗口


browser.maximize_window()


3.3 最小化浏览器窗口(Selenium4支持)


browser.minimize_window()


3.4 全屏窗口


类似浏览器中按下【F11】


browser.fullscreen_window()


3.5 访问指定网址


browser.get("https://www.baidu.com") #访问百度


3.6 获取当前页url


browser.current_url


3.7 获取当前页的title


browser.title


3.8 获取当前页窗口句柄


browser.current_window_handle


3.9 截屏当前窗口


browser.save_screenshot('test.png')  #截取当前窗口并命名为`test.png`保存


3.10 刷新


browser.refresh()


3.11 前进(浏览器的【前进】按钮)


browser.forward()


3.12 后退(浏览器的【后退】按钮)


browser.back()


3.13 设置浏览器大小


设置浏览器宽为480,高为800


browser.set_window_size(480, 800)


3.14 设置浏览器位置


设置浏览器宽为480,高为800


browser.set_window_position(480, 800)


3.15 获取浏览器大小


设置浏览器宽为480,高为800


browser.get_window_size(480, 800)


3.16 获取浏览器位置


设置浏览器宽为480,高为800


browser.get_window_position(480, 800)


3.17 执行js脚本


如果需要进行页面滑动(模拟鼠标滚轮操作)可以通过执行js脚本实现

例如滑动到'//*[@id="asideHotArticle"]/h3'元素:


target


3.18 切换窗口


有多个窗口时,可以通过下面的方法进行切换才能够顺利的进行定位


browser.switch_to.window(browser.window_handles[1])


3.19 切换iframe


页面中的iframe弹窗,需要使用下面的代码切换才能够顺利的进行定位

iframe = browser.find_element(By.CSS_SELECTOR, "#modal > iframe")
# 切换到iframe
browser.switch_to.frame(iframe)


如果iframe有明确的id则可以直接这样写


driver.switch_to.frame('appIframe-product')


3.20 离开iframe


离开iframe,回到默认页面


browser.switch_to.default_content()


3.21 关闭当前窗口


有多个页面的时候,只会关闭当前所在页面


browser.close()


3.22 退出浏览器


会直接关闭浏览器,所有页面都将关闭


browser.quit()


四、总结


实际上webdriver的操作还有很多,比如远程控制项的配置,cookie相关配置等,但都不常用,掌握这些些已经足够了!

目录
相关文章
|
2月前
|
Web App开发 数据采集 存储
WebDriver与Chrome DevTools Protocol:如何在浏览器自动化中提升效率
本文探讨了如何利用Chrome DevTools Protocol (CDP) 与 Selenium WebDriver 提升浏览器自动化效率,结合代理IP技术高效采集微博数据。通过CDP,开发者可直接操作浏览器底层功能,如网络拦截、性能分析等,增强控制精度。示例代码展示了如何设置代理IP、cookie及user-agent来模拟真实用户行为,提高数据抓取成功率与稳定性。适用于需要频繁抓取互联网数据的应用场景。
435 3
WebDriver与Chrome DevTools Protocol:如何在浏览器自动化中提升效率
|
10天前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
44 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
1月前
|
开发框架 安全 JavaScript
xss漏洞原理(四)自动化XSS
xss漏洞原理(四)自动化XSS
|
2月前
|
数据采集 Web App开发 测试技术
使用Selenium与WebDriver实现跨浏览器自动化数据抓取
在网络爬虫领域,Selenium与WebDriver是实现跨浏览器自动化数据抓取的利器。本文详细介绍了如何利用Selenium和WebDriver结合代理IP技术提升数据抓取的稳定性和效率。通过设置user-agent和cookie来模拟真实用户行为,避免被网站检测和阻止。文章提供了具体的代码示例,展示了如何配置代理IP、设置user-agent和cookie,并实现了跨浏览器的数据抓取。合理的参数配置能有效减少爬虫被封禁的风险,提高数据抓取效率。
287 6
使用Selenium与WebDriver实现跨浏览器自动化数据抓取
|
2月前
|
Web App开发 JavaScript Java
自动化测试的利剑:Selenium WebDriver入门与实践
【9月更文挑战第21天】在软件开发的海洋中,自动化测试犹如一艘船,帮助开发者们快速航行至质量保证的彼岸。本文将作为你的罗盘,指引你了解和掌握Selenium WebDriver这一强大的自动化测试工具。通过深入浅出的方式,我们将探索Selenium WebDriver的基本概念、安装过程以及编写简单测试脚本的方法。无论你是刚接触自动化测试的新手,还是希望提升测试技能的开发者,这篇文章都将为你提供有价值的指导。
|
2月前
|
Web App开发 Java 测试技术
自动化测试的利器:Selenium WebDriver入门与实践
【9月更文挑战第8天】在软件开发的海洋中,测试是确保我们不会溺水的那根救生索。Selenium WebDriver,作为自动化测试的明星工具,让这根救生索更加结实可靠。本文将带你快速上手Selenium WebDriver,从基础设置到实际操作,再到实战演练,让你的开发之旅更加平稳顺畅。
|
3月前
|
前端开发 测试技术 UED
【测试效率对比】深入分析:为何UI自动化测试的投资回报率通常低于接口自动化测试?
这篇文章深入分析了UI自动化测试与接口自动化测试的投资回报率(ROI)问题,指出UI自动化测试在某些情况下的ROI并不低,反驳了没有实施过UI自动化就轻易下结论的观点,并强调了实践的重要性和自动化测试在项目迭代中的作用。
80 1
|
3月前
|
XML Java 测试技术
Selenium WebDriver自动化测试(基础篇):不得不掌握的Java基础
关于Selenium WebDriver自动化测试的Java基础篇,涵盖了Java的变量、数据类型、字符串操作、运算符、流程控制、面向对象编程、关键字用法、权限修饰符、异常处理和IO流等基础知识点,为进行自动化测试提供了必要的Java语言基础。
103 1
|
3月前
|
小程序 前端开发 持续交付
小程序全栈开发中的CI/CD流程与自动化部署是一种高效的开发模式。
本文探讨小程序全栈开发中的CI/CD流程与自动化部署,介绍持续集成与部署的概念,包括自动化构建、测试、代码审查及部署实践。通过提高代码质量、迭代速度及团队协作效率,确保小程序稳定运行与良好用户体验。
84 2
|
3月前
|
Web App开发 Java 测试技术
自动化测试的新篇章:使用Selenium WebDriver进行高效测试
【8月更文挑战第31天】 在软件开发的海洋中,自动化测试犹如一艘航船,带领着质量保证团队驶向效率与精准的彼岸。本文将揭开Selenium WebDriver的神秘面纱,通过实际案例引导您掌握这一强大的自动化测试工具。我们将从Selenium WebDriver的基础概念出发,逐步深入到代码示例,最后探讨其在现实项目中的应用场景和优势,旨在为您的软件测试之旅提供清晰的指南。