1.简介
今天这一篇宏哥主要介绍playwright如何在IE、Chrome和Firefox三个浏览器上处理不信任证书的情况,我们知道,有些网站打开是弹窗,SSL证书不可信任,但是你可以点击高级选项,继续打开不安全的链接。举例来说,想必大家都应该用过前几年的12306网站购票,点击新版购票,是不会出现如下的界面。宏哥又找了一个https的页面,不过现在这种网站很少了,主要原因就是大家越来越觉得安全的重要性,想要找到这么个网站可是不容易,费了好久,一个客户的VPN刚好是这种情况,如下图所示:
2.三种浏览器如何处理不受信任的证书
在selenium系列文章中三种浏览器访问网页,弹出证书不信任,需要点击下信任继续访问才行,绝大多数是在访问https的网页。那么我们在做自动化测试的时候,如何跳过这一步骤,直接访问到我们需要的页面了,这个就是今天宏哥主要分享和讲解的如何在三大浏览器跳过这一步骤。因此宏哥在playwright中也觉得类似差不多,甚至会更简单,但是代码写完后,宏哥直接傻眼了,结果出乎意料啊,完全不一样啊!!!playwright直接都没有访问到那个安全提示的页面,就报错了: ** message='net::ERR_CERT_AUTHORITY_INVALID at https://122.225.125.90:8899/** 。
2.1访问证书不信任的网站
我们平时如果遇到证书不信任的网站,就会下一步下一下一直点击下去,知道访问到网站,如下图所示:
宏哥信心满满的按照以上步骤开始编写脚本代码。
2.2代码设计
2.3参考代码
package com.bjhg.playwright;
import com.microsoft.playwright.Browser;
import com.microsoft.playwright.BrowserContext;
import com.microsoft.playwright.BrowserType;
import com.microsoft.playwright.Page;
import com.microsoft.playwright.Playwright;
/**
* @author 北京-宏哥
*
* @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货)
*
* 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-35-访问https 安全问题或者非信任站点(详细教程)
*
* 2025年08月22日
*/
public class Test_Https {
public static void main(String[] args) {
// TODO Auto-generated method stub
try (Playwright playwright = Playwright.create()) {
//1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。
Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(300));
//2.创建context
BrowserContext context = browser.newContext();
//创建page
Page page = context.newPage();
//3.浏览器访问demo
page.navigate("https://122.225.125.90:8899");
Thread.sleep(300);
//4.定位页面的高级按钮并点击
page.locator("#details-button").click();
//5.定位继续前往122.225.125.90(不安全)并点击,即可访到网站
page.locator("proceed-link").click();
System.out.println("Test Pass");
Thread.sleep(500);
//5.关闭page
page.close();
//6.关闭browser
browser.close();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
2.4运行代码
1.运行代码,右键Run As->Java Application,就可以看到控制台输出,如下图所示:
2.运行代码后电脑端的浏览器的动作(根本没有访问到页面,直接就报错了)。如下图所示:
3.解决方案
1.宏哥网上查了有关报错的资料说是有关证书安全或则信任的错误,那么遇到这种我们怎么处理呢???首先确定的之前那种定位到【详细信息】,点击,然后再定位到【转到此网页(不推荐)】点击的方法不能用了,因为根本就没有访问到这个页面,怎么定位点击。
2.既然第一种不行,那就另辟蹊径,看看这种方法:playwright 设置 ignoreHTTPSErrors 参数忽略 SSL 错误 。
3.1context上下文中设置
context()设置 ignoreHTTPSErrors 参数忽略 SSL 错误,语法如下:
// 参数说明
setIgnoreHTTPSErrors(true) 访问https地址解决安全证书
// eg:
context = browser.new_context(new Browser.NewContextOptions().setIgnoreHTTPSErrors(true));
4.项目实战-context上下文中设置
4.1代码设计
4.2参考代码
package com.bjhg.playwright;
import com.microsoft.playwright.Browser;
import com.microsoft.playwright.BrowserContext;
import com.microsoft.playwright.BrowserType;
import com.microsoft.playwright.Page;
import com.microsoft.playwright.Playwright;
/**
* @author 北京-宏哥
*
* @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货)
*
* 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-35-访问https 安全问题或者非信任站点(详细教程)
*
* 2025年08月22日
*/
public class Test_Https {
public static void main(String[] args) {
// TODO Auto-generated method stub
try (Playwright playwright = Playwright.create()) {
//1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。
Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(300));
//2.创建context
BrowserContext context = browser.newContext(new Browser.NewContextOptions().setIgnoreHTTPSErrors(true));
//创建page
Page page = context.newPage();
//3.浏览器访问demo
page.navigate("https://122.225.125.90:8899");
Thread.sleep(300);
//4.定位页面的用户名,输入:北京-宏哥
page.locator("#svpn_name").fill("北京-宏哥");
//5.定位密码,输入:111111
page.locator("#svpn_password").fill("111111");
//6.定位登录点击
page.locator("#logButton").click();
System.out.println("Test Pass");
Thread.sleep(100);
//5.关闭page
page.close();
//6.关闭browser
browser.close();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
4.3运行代码
1.运行代码,右键Run As->Java Application,就可以看到控制台输出,如下图所示:
2.运行代码后电脑端的浏览器的动作(开始看不到底部,最后操作后直接到底部)。如下图所示:
5.小结
到此遇到了类似的问题就可以参考宏哥的方法就行解决了,宏哥这里仅仅讲解和分享了一下Chrome浏览器,其他的浏览器类似的处理方法,不过宏哥没有试过,不一定能成功,有兴趣的童鞋或者小伙伴们可以尝试一下。
在实践过程中,宏哥延续之前的代码只是加了参数,然后运行代码后,虽然也能访问到网站,但是一直报错元素找不到,然后超时了。忽然想到,加了参数已经忽略证书验证,直接就可以访问到网站,而代码中却保持之前的类似手工一步一步的点击,所以才会定位找不到这一步一步的元素,去掉后就好了,还有就是在python中的参数可以加到context的上下文中和page中,但是在Java中就可以加在context上下文中,找了好久也没有找到可以加在page的资料,官网也查了没有。注意这是和python的区别。
好了,时间不早了,今天就分享到这里,感谢大家耐心的阅读!!!