1. 改变用户代理
  2. 读取Cookies
  3. 调用Java Script
  4. Webdriver截图
  5. 页面等待

1. 改变用户代理

  1. import org.junit.AfterClass;
  2. import org.junit.BeforeClass;
  3. import org.junit.Test;
  4. import org.openqa.selenium.WebDriver;
  5. import org.openqa.selenium.firefox.FirefoxDriver;
  6. import org.openqa.selenium.firefox.FirefoxProfile;
  7. public class ProxyTest {
  8. static WebDriver driver;
  9. @BeforeClass
  10. public static void beforeClass(){
  11. //代理的IP和端口
  12. String proxyIP="192.168.12.0";
  13. int proxyPort=80;
  14. FirefoxProfile profile=new FirefoxProfile();
  15. //使用代理
  16. profile.setPreference("network.proxy.type", 1);
  17. //配置“HTTP代理:(N)”
  18. profile.setPreference("network.proxy.http", proxyIP);
  19. profile.setPreference("network.proxy.http_prot", proxyPort);
  20. //选中 “为所有协议使用相同代理(S)” 选框
  21. profile.setPreference("network.proxy.share_proxy_settings", true);
  22. //配置“不使用代理:(N)”文本框
  23. profile.setPreference("network.proxy.no_proxies_on", "localhost, 127.0.0.1");
  24. //以代理的方式启动火狐
  25. driver=new FirefoxDriver(profile);
  26. }
  27. @Test
  28. public void test() {
  29. driver.get("http://www.baidu.com");
  30. }
  31. @AfterClass
  32. public static void afterClass(){
  33. //driver.quit();
  34. }
  35. }

运行之后,在打开的火狐上查看代理设置(选项->高级->网络->连接->设置),显示如下:

友情提示:测试完之后一定要改回来。默认是“使用系统代理设置”。

2.读取Cookies

增加cookie:

Cookie cookie = new Cookie("key", "value");

driver.manage().addCookie(cookie);

获取cookie的值:

Set<Cookie> allCookies = driver.manage().getCookies();

根据某个cookie的name获取cookie的值:

driver.manage().getCookieNamed("cookieName");

删除cookie:

driver.manage().deleteCookieNamed("CookieName");

driver.manage().deleteCookie(loadedCookie);

driver.manage().deleteAllCookies();

下面是一个例子:

  1. import java.util.Set;
  2. import org.junit.After;
  3. import org.junit.Before;
  4. import org.junit.Test;
  5. import org.openqa.selenium.Cookie;
  6. import org.openqa.selenium.WebDriver;
  7. import org.openqa.selenium.firefox.FirefoxDriver;
  8. public class CookieTest {
  9. WebDriver driver;
  10. @Before
  11. public void setUp() throws Exception {
  12. driver=new FirefoxDriver();
  13. }
  14. @After
  15. public void tearDown() throws Exception {
  16. driver.quit();
  17. }
  18. @Test
  19. public void test() {
  20. printCookie();
  21. //添加一个cookie
  22. Cookie cookie=new Cookie("s","selenium");
  23. driver.manage().addCookie(cookie);
  24. printCookie();
  25. //删除一个cookie
  26. driver.manage().deleteCookie(cookie);   //driver.manage().deleteCookieNamed("s");也可以
  27. printCookie();
  28. }
  29. public void printCookie(){
  30. //获取并打印所有的cookie
  31. Set<Cookie> allCookies=driver.manage().getCookies();
  32. System.out.println("----------Begin---------------");
  33. for(Cookie c:allCookies){
  34. System.out.println(String.format("%s->%s",c.getName(),c.getValue()));
  35. }
  36. System.out.println("----------End---------------");
  37. }
  38. }

运行结果显示为:

----------Begin---------------
----------End---------------
----------Begin---------------
s->selenium
----------End---------------
----------Begin---------------
----------End---------------
可以看到添加cookie之前,系统的cookie为空。之后成功添加了cookie(s,selenium)并且最后成功删除。

3. 调用Java Script

selenium提供了executeScriptexecuteAsyncScript两个方法来处理js调用的问题。其中executeScript是同步方法,用它执行js代码会阻塞主线程执行,直到js代码执行完毕;executeAsyncScript方法是异步方法,它不会阻塞主线程执行。

  1. import org.junit.Test;
  2. import org.openqa.selenium.WebDriver;
  3. import org.openqa.selenium.firefox.FirefoxDriver;
  4. import org.openqa.selenium.JavascriptExecutor;
  5. public class JSTest {
  6. @Test
  7. public void test() {
  8. WebDriver driver=new FirefoxDriver();
  9. driver.get("http://www.baidu.com");
  10. JavascriptExecutor js=(JavascriptExecutor)driver;
  11. js.executeScript("document.getElementById(\"kw\").value=\"selenium\"");
  12. //利用js代码获取百度搜索框内文字
  13. String keyword = (String) (js.executeScript("var input = document.getElementById(\"kw\").value;return input"));
  14. System.out.println(keyword);
  15. driver.quit();
  16. }
  17. }

运行结果:

selenium

4. Webdriver截图

  1. import java.io.File;
  2. import java.io.IOException;
  3. import org.apache.commons.io.FileUtils;
  4. import org.junit.Test;
  5. import org.openqa.selenium.OutputType;
  6. import org.openqa.selenium.TakesScreenshot;
  7. import org.openqa.selenium.WebDriver;
  8. import org.openqa.selenium.firefox.FirefoxDriver;
  9. public class ScreenShotTest {
  10. @Test
  11. public void test() {
  12. WebDriver driver=new FirefoxDriver();
  13. driver.get("http://www.baidu.com");
  14. screenShot("selenium.jpg", (TakesScreenshot)driver);
  15. driver.quit();
  16. }
  17. public static void screenShot(String name,TakesScreenshot driver){
  18. String savaPath=System.getProperty("user.dir");
  19. File sourceFile=driver.getScreenshotAs(OutputType.FILE);
  20. try{
  21. System.out.println("Begin saving screenshot to path:"+savaPath);
  22. FileUtils.copyFile(sourceFile, new File(savaPath+"\\"+name));
  23. } catch(IOException e){
  24. System.out.println("Save screenshot failed!");
  25. e.printStackTrace();
  26. } finally{
  27. System.out.println("Finish screenshot!");
  28. }
  29. }
  30. }

运行结果:

Begin saving screenshot to path:D:\workspace_luna\SeleniumDemo
Finish screenshot!

由于eclipse的workspace不一样,会导致上面的路径不一样。不过没关系,我们打开对应的路径就可以看到selenium.jpg。打开以后是百度首页的截图。

5. 页面等待

因为Load页面需要一段时间,如果页面还没加载完就查找元素,必然是查找不到的。最好的方式,就是设置一个默认等待时间,在查找页面元素的时候如果找不到就等待一段时间再找,直到超时。Webdriver提供两种方法,一种是显性等待,另一种是隐性等待。

显性等待:

显示等待就是明确的要等到某个元素的出现或者是某个元素的可点击等条件,等不到,就一直等,除非在规定的时间之内都没找到,那么就跳出Exception.

  1. new WebDriverWait(driver, 10).until(ExpectedConditions.presenceOfElementLocated(By.id("kw")));

当然也可以自己重写内部类:

  1. WebElement e = (new WebDriverWait( driver, 10)).until(
  2. new ExpectedCondition< WebElement>(){
  3. @Override
  4. public WebElement apply( WebDriver d) {
  5. return d.findElement(By.linkText("Selenium_百度百科"));
  6. }
  7. });

下面的例子是:打开百度,搜索“selenium",等待搜索结果里出现“Selenium_百度百科”的时候点击该链接。

  1. import org.junit.Test;
  2. import org.openqa.selenium.By;
  3. import org.openqa.selenium.WebDriver;
  4. import org.openqa.selenium.WebElement;
  5. import org.openqa.selenium.firefox.FirefoxDriver;
  6. import org.openqa.selenium.support.ui.ExpectedCondition;
  7. import org.openqa.selenium.support.ui.ExpectedConditions;
  8. import org.openqa.selenium.support.ui.WebDriverWait;
  9. public class ExplicitWaitTest {
  10. @Test
  11. public void test() {
  12. WebDriver driver=new FirefoxDriver();
  13. driver.get("http://www.baidu.com");
  14. driver.findElement(By.id("kw")).sendKeys("selenium");
  15. driver.findElement(By.id("su")).click();
  16. //方法一
  17. //new WebDriverWait(driver,10).until(ExpectedConditions.presenceOfElementLocated(By.linkText("Selenium_百度百科")));
  18. //driver.findElement(By.linkText("Selenium_百度百科")).click();
  19. //方法二
  20. WebElement e = (new WebDriverWait( driver, 10)).until(
  21. new ExpectedCondition< WebElement>(){
  22. @Override
  23. public WebElement apply( WebDriver d) {
  24. return d.findElement(By.linkText("Selenium_百度百科"));
  25. }
  26. }
  27. );
  28. e.click();
  29. driver.quit();
  30. }
  31. }

运行的话是通过的,但是如果中间不显示等待的话,直接查找就会fail。

隐性等待:

隐形等待只是等待一段时间,元素不一定要出现,只要时间到了就会继续执行。

  1. driver.manage().timeouts().implicitlyWait(second, TimeUnit.SECONDS);

还是上面的例子,用隐性等待写就是:

  1. import java.util.concurrent.TimeUnit;
  2. import org.junit.Test;
  3. import org.openqa.selenium.By;
  4. import org.openqa.selenium.WebDriver;
  5. import org.openqa.selenium.firefox.FirefoxDriver;
  6. public class ImplicitWaitTest {
  7. @Test
  8. public void test() {
  9. WebDriver driver=new FirefoxDriver();
  10. driver.get("http://www.baidu.com");
  11. driver.findElement(By.id("kw")).sendKeys("selenium");
  12. driver.findElement(By.id("su")).click();
  13. driver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS);
  14. driver.findElement(By.linkText("Selenium_百度百科")).click();
  15. driver.quit();
  16. }
  17. }

运行结果还是通过的。不过个人觉得看起来跟笨方法”Thread.sleep()"差不多,只不多比它更高效了而已。

最新文章

  1. JS判断是不是手机浏览器浏览网站的网页,并自动跳转
  2. tensorflow 学习(一)
  3. Activity启动方式
  4. 动态规划(树形DP):HDU 5886 Tower Defence
  5. MVC入门之.Net语法学习
  6. Ubuntu server 14.04 交叉编译Unicorn-engine
  7. ubuntu 安装Opencv2.4.7
  8. 移动应用开发者最应该知道的8款SDK
  9. AsyncLocal的运作机制和陷阱
  10. [国嵌攻略][068][tftp网络协议实现]
  11. [Go] golang的error接口
  12. jquery中的globalEval()源码分析
  13. STL之pair对组
  14. eclipse中如何打开工作空间里面已经有的项目
  15. 在UWP中自定义半边框样式的输入框
  16. 每天CSS学习之letter-spacing
  17. PHP ueditor编辑器使用(TP5)
  18. CH4401 蒲公英
  19. 高精度算r的n次方 问题 H: 乾隆巡江南
  20. WebView动态注入JavaScript脚本

热门文章

  1. 近似推断(Approximate Inference)
  2. javascript -- 事件捕获,事件冒泡
  3. 【BZOJ】1101: [POI2007]Zap(莫比乌斯+分块)
  4. ES插件elasticsearch-mapper-attachments 2.3.4及各个版本正确下载地址
  5. strust2自定义interceptor的基本方法及操作
  6. C# 压缩和解压文件(SharpZipLib)
  7. [python]常用的几个包
  8. 【BZOJ2783】[JLOI2012]树 DFS+栈+队列
  9. maven 基本框架搭建
  10. LeetCode 笔记系列十 Suduko