這一篇宏哥主要介紹playwright如何在IE、Chrome和Firefox三個瀏覽器上處理不信任證書的情況,我們知道,有些網站開啟是彈窗,SSL證書不可信任,但是你可以點選高階選項,繼續開啟不安全的連結。舉例來說,想必大家都應該用過前幾年的12306網站購票,點選新版購票,是不是會出現如下的介面。宏哥又找了一個https的頁面,不過現在這種網站很少了,主要原因就是大家越來越覺得安全的重要性,想要找到這麼個網站可是不容易,費了好久,一個客戶的VPN剛好是這種情況,如下圖所示:
在selenium三種瀏覽器存取網頁,彈出證書不信任,需要點選下信任繼續存取才行,多為存取https的網頁。那麼我們在做自動化測試的時候,如何跳過這一步驟,直接存取到我們需要的頁面了,這個就是宏哥主要分享和講解的如何在三大瀏覽器跳過這一步驟。因此宏哥在playwright中也覺得類似差不多,但是程式碼寫完後,宏哥直接傻眼了,完全不一樣啊!!!playwright直接都沒有存取到那個安全提示的頁面,就報錯了:playwright._impl._api_types.Error: net::ERR_CERT_AUTHORITY_INVALID at。
1.宏哥網上查了有關資料說是有關證書安全或則信任的錯誤,那麼遇到這種我們怎麼處理呢???首先確定的之前那種定位到【詳細資訊】,點選,然後再定位到【轉到此網頁(不推薦)】點選的方法不能用了,因為根本就沒有存取到這個頁面,怎麼定位點選。
2.既然第一種不行,那就另闢蹊徑,看看這種方法:playwright 設定 ignore_https_errors 引數忽略 SSL 錯誤 。
context()設定 ignore_https_errors 引數忽略 SSL 錯誤,語法如下:
# 引數說明 ignore_https_errors=True 存取https地址解決安全證書 viewport={"width": 1920, "height": 1080} 最大化開啟瀏覽器,引數可設定。 eg: context = browser.new_context(ignore_https_errors=True, viewport={"width": 1920, "height": 1080})
page()設定 ignore_https_errors 引數忽略 SSL 錯誤,語法如下:
# 引數說明 ignore_https_errors=True 存取https地址解決安全證書 viewport={"width": 1920, "height": 1080} 最大化開啟瀏覽器,引數可設定。 eg: page = browser.new_page(ignore_https_errors=True, viewport={"width": 1920, "height": 1080})
# coding=utf-8