1.简介
通过前边两篇文章跟随宏哥学习想必到这里已经将环境搭建好了,今天就在Java项目搭建环境中简单地实践一下: 启动两大浏览器。按市场份额来说,全球前三大浏览器是:IE.Firefox.Chrome。但是微软已经在Win10中不维护IE浏览器了,用Edge浏览器代替或者兼容IE模式的浏览器,因此宏哥这里主要介绍一下如何在Windows系统中启动这两大浏览器即可,其他平台系统的浏览器类似的启动方法,照猫画虎就可以了。但是在实践过程中,宏哥发现Java语言的Playwright目前好像支持三款浏览器:Chrome、Firefox和Webkit,索性就全部讲解和介绍了吧。可能有的小伙伴或者童鞋们不相信就仅仅支持三款浏览器,也可能是宏哥理解错了,欢迎纠错哦!下边说一下宏哥的依据。
1.1下载的浏览器
跟随宏哥首先看一下,我们运行代码下载的浏览器,只有三款:Chrome、Firefox和Webkit。如下图所示:
data:image/s3,"s3://crabby-images/a3298/a3298b3babe334ea8de97bba63b4a98419b8343a" alt=""
1.2BrowserType(浏览器类型)
再跟随随宏哥,看一下代码中提供的浏览器类型就三个:chromium()、firefox()和webkit(),如下图所示:
data:image/s3,"s3://crabby-images/30b8a/30b8ad5016291345fee4478e3206200e8c812990" alt=""
2.启动浏览器准备工作
2.1准备工作
创建一个Playwright的Java项目,用来练习,具体步骤如下:
1.打开Eclipse,创建一个名称为bjhg_playwright的Java 项目,如下图所示:
data:image/s3,"s3://crabby-images/6d143/6d1437e86d4df98f2ef7232ea0193d2c16f7ab4d" alt=""
2.选择项目,右键项目,选择Build Path,然后选择Confige Build Path...,弹出框点击Libraries,如下图所示:
data:image/s3,"s3://crabby-images/3cf35/3cf3558ac2b7a086bb5b1a93a1ed07a01f212534" alt=""
3.这里点击Add External JARs...,弹出框,选择当前电脑本地之前下载好的所有与playwright相关的jar包,添加到新建的项目中,如下图所示:
data:image/s3,"s3://crabby-images/8beac/8beac29c87e236bf9e23fd53df85f0dcd1ded3a8" alt=""
4.点击"OK",如下图所示:
data:image/s3,"s3://crabby-images/be825/be8256033d026f7e656bbc457cd7201663fe5d3e" alt=""
准备工作就介绍到这里,下边介绍如何启动两大浏览器。
3.启动Chrome浏览器
大致思路:打开Chrome浏览器,访问百度网址,获取网址的title,然后再关闭Chrome浏览器。根据思路进行代码设计。
3.1代码设计
data:image/s3,"s3://crabby-images/f7fb8/f7fb8eacd2dcb7a4d330b068a5f42959ed5140cf" alt=""
3.2参考代码
package bjhg_playwright;
import com.microsoft.playwright.Browser;
import com.microsoft.playwright.BrowserType;
import com.microsoft.playwright.Page;
import com.microsoft.playwright.Playwright;
/**
* @author 北京-宏哥
*
* @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货)
*
* 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-3-启动浏览器(详细教程)
*
* 2024年7月09日
*/
public class LaunchChrome {
public static void main(String[] args) {
try (Playwright playwright = Playwright.create()) {
Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(50));
Page page = browser.newPage();
page.navigate("https://www.baidu.com/");
System.out.println(page.title());
page.close();
}
}
}
3.3运行代码
1.运行代码,右键Run AS->java Application,就可以看到控制台输出,如下图所示:
data:image/s3,"s3://crabby-images/bee6e/bee6e9a2c691804289bd0591562552f44e5268d3" alt=""
2.运行代码后电脑端的浏览器的动作。如下图所示:
data:image/s3,"s3://crabby-images/7c722/7c7228f5aefa0a91cbe0472a5c0b87c3a4e6f8bb" alt=""
4.启动Firefox浏览器
大致思路和启动Chrome浏览器相同:打开Firefox浏览器,访问百度网址,获取网址的title,然后再关闭Firefox浏览器。根据思路进行代码设计。
4.1代码设计
data:image/s3,"s3://crabby-images/e17f9/e17f91dd235216541d5bbe1cc1fb2b47eccd05a8" alt=""
4.2参考代码
package bjhg_playwright;
import com.microsoft.playwright.Browser;
import com.microsoft.playwright.BrowserType;
import com.microsoft.playwright.Page;
import com.microsoft.playwright.Playwright;
/**
* @author 北京-宏哥
*
* @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货)
*
* 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-3-启动浏览器(详细教程)
*
* 2024年7月09日
*/
public class LaunchFirefox {
public static void main(String[] args) {
try (Playwright playwright = Playwright.create()) {
Browser browser = playwright.firefox().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(50));
Page page = browser.newPage();
page.navigate("https://www.baidu.com/");
System.out.println(page.title());
page.close();
}
}
}
4.3运行代码
1.运行代码,右键Run AS->java Application,就可以看到控制台输出,如下图所示:
data:image/s3,"s3://crabby-images/138c0/138c008e6fc9ad9d499ccefcf16a950e2386e762" alt=""
2.运行代码后电脑端的浏览器的动作。如下图所示:
data:image/s3,"s3://crabby-images/56892/5689293a0a0acdf394b8ade6b4b2d91790cdf94a" alt=""
5.启动webkit浏览器
大致思路和启动Chrome浏览器相同:打开webkit浏览器,访问百度网址,获取网址的title,然后再关闭webkit浏览器。根据思路进行代码设计。
5.1代码设计
data:image/s3,"s3://crabby-images/b4438/b4438364e440506b5d66b8b0438687407454910d" alt=""
5.2参考代码
package bjhg_playwright;
import com.microsoft.playwright.Browser;
import com.microsoft.playwright.BrowserType;
import com.microsoft.playwright.Page;
import com.microsoft.playwright.Playwright;
/**
* @author 北京-宏哥
*
* @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货)
*
* 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-3-启动浏览器(详细教程)
*
* 2024年7月09日
*/
public class LaunchWebkit {
public static void main(String[] args) {
try (Playwright playwright = Playwright.create()) {
Browser browser = playwright.webkit().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(50));
Page page = browser.newPage();
page.navigate("https://www.baidu.com/");
System.out.println(page.title());
page.close();
}
}
}
5.3运行代码
1.运行代码,右键Run AS->java Application,就可以看到控制台输出,如下图所示:
data:image/s3,"s3://crabby-images/1be94/1be942998ed9bcd35d89d98513258313f8ff3616" alt=""
2.运行代码后电脑端的浏览器的动作。如下图所示:
data:image/s3,"s3://crabby-images/94a83/94a830d572ca21a55040e6d9c427b02c9c3bba2a" alt=""
6.关键代码说明
package bjhg_playwright;
import com.microsoft.playwright.Browser;
import com.microsoft.playwright.BrowserType;
import com.microsoft.playwright.Page;
import com.microsoft.playwright.Playwright;
/**
* @author 北京-宏哥
*
* @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货)
*
* 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-3-启动浏览器(详细教程)
*
* 2024年7月09日
*/
public class LaunchChrome {
public static void main(String[] args) {
try (Playwright playwright = Playwright.create()) {
//使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。
Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(50));
//创建page
Page page = browser.newPage();
//浏览器打开百度
page.navigate("https://www.baidu.com/");
//打印title
System.out.println(page.title());
//关闭page
page.close();
}
}
}
通过上边在代码中增加的注释,想必小伙伴或者童鞋们就比较好理解了,也知道宏哥在第一篇文章运行代码时,为何没有看到浏览器UI了吧!
7.小结
宏哥因为之前做过python、java语言和selenium,经常碰到头疼的问题就是:出现浏览器版本和驱动版本匹配的问题,新手一定要注意这个问题。但是playwright无论是Java还是python语言,无论是新手还是老鸟就都不需要担心这些问题了,而且今天讲解和分享的非常简单,就是简单换个方法就可以启动不同的浏览器了。好了,今天关于三大浏览器的驱动宏哥就分享到这里,感谢你耐心的阅读。