一、Selenium简介
Selenium是一个用于Web应用程序自动化测试工具。Selenium测试直接运行在浏览器中,就像真正的用户在
操作一样。支持的浏览器包括IE(7, 8, 9, 10, 11),Mozilla Firefox,Safari,Google Chrome,Opera等。
适用于自动化测试,js动态爬虫(破解反爬虫)等领域。
二、Selenium组成
1)Selenium IDE:嵌入到Firefox浏览器中的一个插件,实现简单的浏览器操作录制与回放功能,主要用于快速创建BUG及重现脚本,可转化为多种语言 2)Selenium RC: 核心组件,支持多种不同语言编写自动化测试脚本,通过其服务器作为代理服务器去访问应用,达到测试的目的 3)Selenium WebDriver(重点):一个浏览器自动化框架,它接受命令并将它们发送到浏览器。它是通过特定于浏览器的驱动程序实现的。它直接与浏览器通信并对其进行控制。Selenium WebDriver支持各种编程语言,如Java、C# 、PHP、Python、Perl、Ruby 4)Selenium grid:测试辅助工具,用于做分布式测试,可以并行执行多个测试任务,提升测试效率。
三、Selenium特点
1)开源、免费 2)多浏览器支持:FireFox、Chrome、IE、Opera、Edge; 3)多平台支持:Linux、Windows、MAC; 4)多语言支持:Java、Python、Ruby、C#、JavaScript、C++; 5)对Web页面有良好的支持; 6)简单(API 简单)、灵活(用开发语言驱动); 7)支持分布式测试用例执行。
四,Selenium使用
新建一个项目用于Selenium演示
导入pom依赖
<dependency> <groupId>org.seleniumhq.selenium</groupId> <artifactId>selenium-java</artifactId> <version>3.141.59</version> </dependency>
下载浏览器驱动
先要知道自己浏览器的版本
小刘使用的是最新版
下载驱动地址: http://chromedriver.storage.googleapis.com/index.html
只看版本前几位最大数即可
点击下载
下载完成:
拷贝到一个非中文目录下
创建一个测试类
Demo1
三行固定代码
第一行中的路径放自己刚刚下载的浏览器驱动包
第三行中的地址放需要去管控的网页地址
执行这三行指令会去自动管控目标网页
获取网页数据
1)Class选择:driver.findElement(By.className("s_ipt"));
通过类选择器拿到被控制的页面的按钮元素
WebElement s_btn = driver.findElement(By.className("s_btn")); System.out.println(s_btn.getAttribute("id")); System.out.println(s_btn.getAttribute("value"));
获取结果
2)ID选择: driver.findElement(By.id("kw"));
WebElement su = driver.findElement(By.id("su")); System.out.println(su.getAttribute("class"));
网页样式
3)name选择: driver.findElement(By.name("wd"));
System.out.println(driver.findElement(By.name("rqlang")).getAttribute("value"));
网页样式:
4)tag选择: driver.findElements(By.tagName("input"));
获取百度首页所有点击链接 List<WebElement> eles = driver.findElements(By.tagName("a")); // 大数据:数据采集 数据清洗 数据可视化 for(WebElement ele : eles){ // ele指的是单个A标签 String text = ele.getText(); if(text != null && !"".equals(text.trim())) System.out.println(text); }
5)link选择: driver.findElement(By.linkText("地图"));
通过链接文本获取链接元素(精准匹配)
并点击链接文本
driver.findElement(By.linkText("地图")).click();
展示效果
6)Partial link选择(a标签文本内容模糊匹配):driver.findElement(By.partialLinkText("使用百"));
代码编写:
List<WebElement> eles = driver.findElements(By.partialLinkText("3"));
for (WebElement ele : eles) {
System.out.println(ele.getText());
}
测试结果:
7)css选择器:driver.findElement(By.cssSelector("#kw"));
通过css选择器获取页面元素
driver.findElement(By.cssSelector("#hotsearch-content-wrapper > li:nth-child(3) > a > span.title-content-title"));
先如下图所示 在页面元素中在文字部分右键选择copy 再选择 copy selector即可复制
#hotsearch-content-wrapper > li:nth-child(3) > a > span.title-content-title
执行效果:
8)xpath选择:driver.findElement(By.xpath("//*[@id="kw"]"));
/students/student/...
复制方法:
//*[@id="hotsearch-content-wrapper"]/li[4]/a/span[2]
执行演示:
**WebElement ele = driver.findElement(By.xpath("//*[@id=\"hotsearch-content-wrapper\"]/li[4]/a/span[2]")); System.out.println(ele.getText()); **
2.获取单个元素:driver.findElement
代码截图:
代码:
//拿到百度首页的input输入框 WebElement element = driver.findElement(By.xpath("//*[@id=\"kw\"]")); //模拟往输入框中输入搜索关键字 element.sendKeys("禁止收敛"); //模拟等待 Thread.sleep(3000); //获取百度一下的点击按钮 driver.findElement(By.id("su")).click();
演示结果:
版权归原作者 小刘学编程. 所有, 如有侵权,请联系我们删除。