Selenium Web自动化 原理

时间:2024-09-21 13:34:56

文章转自 白月黑羽教Python

原理

说到web应用自动化测试,第一选择就是 Selenium 框架。

Selenium 是一个 Web 应用的自动化框架。

通过它,我们可以写出自动化程序像人一样(在浏览器里)操作web界面。 比如点击界面按钮,在文本框中输入文本,甚至一些拖拽操作,滚动界面的操作。

并且能够从web界面获取信息。 比如获取某个区域的文字内容,从而通过自动化程序进行分析处理。

Selenium3.0 的自动化架构是这样的

Selenium Web自动化 原理

从上图可以看出:

我们写的自动化程序 需要使用一个Selenium组织提供的 客户端库。

我们程序的自动化请求都是通过使用这个库的接口对象完成的。 比如调用某个元素对象的click方法, 就会发送点击这个元素的请求给 下方的浏览器驱动。

这个自动化程序的请求是通过客户端库,构建出相应的HTTP请求,发送给浏览器驱动的。

浏览器驱动 也是一个独立的程序,是由浏览器厂商提供的, 不同的浏览器需要不同的浏览器驱动。 比如 Chrome浏览器和 火狐浏览器有 各自不同的驱动程序。

浏览器驱动接收到我们的自动化程序发送过来的界面操作请求后,会转发请求给浏览器, 让浏览器去执行对应的自动化操作。

浏览器执行完操作后,会将自动化的结果返回给浏览器驱动, 浏览器驱动再通过http响应的消息返回给我们的自动化程序的客户端库。

自动化程序的客户端库 接收到响应后,将结果转化为 数据对象 返回给我的自动化程序代码。我们的程序就可以知道这次自动化操作的结果如何了。

上述自动化的往返流程都是在我们的程序对Selenium客户端库的调用和返回之间发生的事情。

Selenium组织提供了多种主流编程语言的Selenium客户端库, 方便不同编程语言的开发者使用。

安装

Selenium环境的安装主要就是安装两样东西: 客户端库 和浏览器 驱动

安装客户端库

不同的编程语言选择不同的Selenium客户端库。

对应我们Python语言来说,Selenium客户端库的安装非常简单,用pip 命令即可。

打开 命令行程序,运行如下命令

pip install selenium

安装浏览器驱动

不同的浏览器选择不同的浏览器驱动。

目前来说,主流的浏览器就是 Chrome 和 火狐。 而 Chrome 浏览器对Selenium自动化的支持目前来说更加成熟一些。

我们就以Chrome浏览器为例。

Chrome 浏览器的驱动在谷歌的网站上。大家都知道,谷歌的网站,我们国内访问只能呵呵了。

当然,如果你能***,那么可以访问下面的链接, 获取最新版本的chrome浏览器驱动

https://sites.google.com/a/chromium.org/chromedriver/downloads

点击下图箭头处,下载最新驱动

Selenium Web自动化 原理

注意浏览器驱动 必须要和浏览器版本匹配,如上图红圈里面的声明。

比如:当前Chrome驱动版本是2.37, 支持的Chrome浏览器版本号是 64 到 66 之间都可以。

为了方便不能***的朋友获取最新驱动。

白月黑羽会一直为大家在这里提供Windows版本上最新的驱动下载。大家只需点击下方链接即可

下载链接:Chrome驱动2.37版,支持Chrome浏览器64-66

这是个zip包,下载下来之后里面的程序文件 chromedriver.exe 解压到某个目录下面,注意这个目录的路径最好是没有中文名和空格的。

建议大家解压到 d:\webdrivers 目录下面。

也就是保证我们的Chrome浏览器驱动路径为 d:\webdrivers\chromedriver.exe

安装好以后,如何 使用Python语言结合Selenium编写 Web 自动化呢

访问原文网站,看 下一篇 操作web界面