如何使用Selenium处理证书?

时间:2014-07-01 09:41:35

标签: python selenium python-3.x selenium-webdriver browser

我正在使用Selenium来启动浏览器。如何处理要求浏览器接受证书的网页(URL)?

在Firefox中,我可能有一个这样的网站要求我接受这样的证书:

Firefox

在Internet Explorer浏览器上,我可能会得到这样的结果:

Enter image description here

在Google Chrome上:

Google Chrome

我重复我的问题:当我使用Selenium(Python编程语言)启动浏览器(Internet Explorer,Firefox和Google Chrome)时,如何自动接受网站证书

19 个答案:

答案 0 :(得分:86)

对于Firefox,您需要将accept_untrusted_certs FirefoxProfile()选项设置为True

from selenium import webdriver

profile = webdriver.FirefoxProfile()
profile.accept_untrusted_certs = True

driver = webdriver.Firefox(firefox_profile=profile)
driver.get('https://cacert.org/')

driver.close()

对于Chrome,您需要添加--ignore-certificate-errors ChromeOptions()参数:

from selenium import webdriver

options = webdriver.ChromeOptions()
options.add_argument('--ignore-certificate-errors')

driver = webdriver.Chrome(chrome_options=options)
driver.get('https://cacert.org/')

driver.close()

对于Internet Explorer,您需要设置acceptSslCerts所需的功能:

from selenium import webdriver

capabilities = webdriver.DesiredCapabilities().INTERNETEXPLORER
capabilities['acceptSslCerts'] = True

driver = webdriver.Ie(capabilities=capabilities)
driver.get('https://cacert.org/')

driver.close()

实际上,根据Desired Capabilities documentation,将acceptSslCerts设置为True的功能应适用于所有浏览器,因为它是通用的读/写功能:

  

acceptSslCerts

     

布尔

     

会话是否应接受所有SSL证书   默认情况下。


Firefox的工作演示:

>>> from selenium import webdriver

acceptSslCerts设为False

>>> capabilities = webdriver.DesiredCapabilities().FIREFOX
>>> capabilities['acceptSslCerts'] = False
>>> driver = webdriver.Firefox(capabilities=capabilities)
>>> driver.get('https://cacert.org/')
>>> print(driver.title)
Untrusted Connection
>>> driver.close()

acceptSslCerts设为True

>>> capabilities = webdriver.DesiredCapabilities().FIREFOX
>>> capabilities['acceptSslCerts'] = True
>>> driver = webdriver.Firefox(capabilities=capabilities)
>>> driver.get('https://cacert.org/')
>>> print(driver.title)
Welcome to CAcert.org
>>> driver.close()

答案 1 :(得分:7)

对于Firefox:

ProfilesIni profile = new ProfilesIni();
FirefoxProfile myprofile = profile.getProfile("default");
myprofile.setAcceptUntrustedCertificates(true);
myprofile.setAssumeUntrustedCertificateIssuer(true);
WebDriver driver = new FirefoxDriver(myprofile);

对于 Chrome ,我们可以使用:

DesiredCapabilities capabilities = DesiredCapabilities.chrome();
capabilities.setCapability("chrome.switches", Arrays.asList("--ignore-certificate-errors"));
driver = new ChromeDriver(capabilities);

对于 Internet Explorer ,我们可以使用:

DesiredCapabilities capabilities = new DesiredCapabilities();
capabilities.setCapability(CapabilityType.ACCEPT_SSL_CERTS, true);      
Webdriver driver = new InternetExplorerDriver(capabilities);

答案 2 :(得分:4)

对于Firefox Python:

Firefox自签名证书错误现已修复: accept ssl cert with marionette firefox webdrive python splinter

" acceptSslCerts"应该用" acceptInsecureCerts"

代替
from selenium import webdriver
from selenium.webdriver.common.desired_capabilities import DesiredCapabilities
from selenium.webdriver.firefox.firefox_binary import FirefoxBinary

caps = DesiredCapabilities.FIREFOX.copy()
caps['acceptInsecureCerts'] = True
ff_binary = FirefoxBinary("path to the Nightly binary")

driver = webdriver.Firefox(firefox_binary=ff_binary, capabilities=caps)
driver.get("https://expired.badssl.com")

答案 3 :(得分:3)

    ChromeOptions options = new ChromeOptions().addArguments("--proxy-server=http://" + proxy);
    options.setAcceptInsecureCerts(true);

答案 4 :(得分:2)

对于通过python selenium来解决与无头铬相关的问题的人,您可能会发现https://bugs.chromium.org/p/chromium/issues/detail?id=721739#c102有用。

看起来你可以做到

chrome_options = Options()
chrome_options.add_argument('--allow-insecure-localhost')

或者下面的内容(可能需要适应python):

ChromeOptions options = new ChromeOptions()
DesiredCapabilities caps = DesiredCapabilities.chrome()
caps.setCapability(ChromeOptions.CAPABILITY, options)
caps.setCapability("acceptInsecureCerts", true)
WebDriver driver = new ChromeDriver(caps)

答案 5 :(得分:2)

使用Javascript:

const capabilities = webdriver.Capabilities.phantomjs();
capabilities.set(webdriver.Capability.ACCEPT_SSL_CERTS, true);
capabilities.set(webdriver.Capability.SECURE_SSL, false);
capabilities.set('phantomjs.cli.args', ['--web-security=no', '--ssl-protocol=any', '--ignore-ssl-errors=yes']);
const driver = new webdriver.Builder().withCapabilities(webdriver.Capabilities.chrome(), capabilities).build();

答案 6 :(得分:1)

在硒python中,您需要将desired_capabilities设置为:

desired_capabilities = {
    "acceptInsecureCerts": True
}

答案 7 :(得分:0)

从浏览器的证书存储中删除除必要的证书之外的所有证书,然后将浏览器配置为仅在存在一个证书时自动选择证书。

答案 8 :(得分:0)

关于此问题的最新消息。

需要驱动程序:

Linux: Centos 7 64bit, Window 7 64bit

Firefox: 52.0.3

Selenium Webdriver: 3.4.0 (Windows), 3.8.1 (Linux Centos)

GeckoDriver: v0.16.0 (Windows), v0.17.0 (Linux Centos)

代码

System.setProperty("webdriver.gecko.driver", "/home/seleniumproject/geckodrivers/linux/v0.17/geckodriver");

ProfilesIni ini = new ProfilesIni();


// Change the profile name to your own. The profile name can 
// be found under .mozilla folder ~/.mozilla/firefox/profile. 
// See you profile.ini for the default profile name

FirefoxProfile profile = ini.getProfile("default"); 

DesiredCapabilities cap = new DesiredCapabilities();
cap.setAcceptInsecureCerts(true);

FirefoxBinary firefoxBinary = new FirefoxBinary();

GeckoDriverService service =new GeckoDriverService.Builder(firefoxBinary)
    .usingDriverExecutable(new 
File("/home/seleniumproject/geckodrivers/linux/v0.17/geckodriver"))
    .usingAnyFreePort()
    .usingAnyFreePort()
    .build();
try {
    service.start();
} catch (IOException e) {
    e.printStackTrace();
}

FirefoxOptions options = new FirefoxOptions().setBinary(firefoxBinary).setProfile(profile).addCapabilities(cap);

driver = new FirefoxDriver(options);
driver.get("https://www.google.com");

System.out.println("Life Title -> " + driver.getTitle());
driver.close();

答案 9 :(得分:0)

我能够使用带有硒Web驱动程序3.1的PhantomJSDriver在.net c#上做到这一点

 [TestMethod]
    public void headless()
    {


        var driverService = PhantomJSDriverService.CreateDefaultService(@"C:\Driver\phantomjs\");
        driverService.SuppressInitialDiagnosticInformation = true;
        driverService.AddArgument("--web-security=no");
        driverService.AddArgument("--ignore-ssl-errors=yes");
        driver = new PhantomJSDriver(driverService);

        driver.Navigate().GoToUrl("XXXXXX.aspx");

        Thread.Sleep(6000);
    }

答案 10 :(得分:0)

对于使用 Firefox 来解决此问题的人,上述解决方案不起作用,您可以尝试以下代码(我的原始答案是here)。

from selenium import webdriver

profile = webdriver.FirefoxProfile()
profile.DEFAULT_PREFERENCES['frozen']['marionette.contentListener'] = True
profile.DEFAULT_PREFERENCES['frozen']['network.stricttransportsecurity.preloadlist'] = False
profile.DEFAULT_PREFERENCES['frozen']['security.cert_pinning.enforcement_level'] = 0
profile.set_preference('webdriver_assume_untrusted_issuer', False)
profile.set_preference("browser.download.folderList", 2)
profile.set_preference("browser.download.manager.showWhenStarting", False)
profile.set_preference("browser.download.dir", temp_folder)
profile.set_preference("browser.helperApps.neverAsk.saveToDisk",
                   "text/plain, image/png")
driver = webdriver.Firefox(firefox_profile=profile)

答案 11 :(得分:0)

在C#(。net核心)中使用Selenium.WebdriverSelenium.Chrome.Webdriver像这样:

ChromeOptions options = new ChromeOptions();
options.AddArgument("--ignore-certificate-errors");
using (var driver = new ChromeDriver(Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location),options))
{ 
  ...
}

答案 12 :(得分:0)

每当我在较新的浏览器中遇到此问题时,我仅使用AppRobotic Personal版本单击特定的屏幕坐标,或通过按钮进行制表并单击。

基本上,它仅使用其宏功能,但在无头设置中将无法使用。

答案 13 :(得分:0)

我遇到了Selenium和Behat的同一问题。如果您想通过behat.yml传递参数,则其外观应如下所示:

default:
    extensions:
        Behat\MinkExtension:
            base_url: https://my-app.com
            default_session: selenium2
            selenium2:
                browser: firefox
                capabilities:
                    extra_capabilities:
                        acceptInsecureCerts: true

答案 14 :(得分:0)

我遇到了完全相同的问题。但是,当我尝试在浏览器中手动打开网站时,证书是正确的,但在详细信息中,名称为“ DONOTTRUST”。

证书的差异是由Fiddler在后台运行并在重新加密之前解密所有HTTPS内容引起的。

要解决我的问题,只需在机器上关闭Fiddler。如果需要保持Fiddler处于打开状态,则可以取消选中“ Fiddler设置”中的“解密SSL”。

答案 15 :(得分:0)

WebDriverManager.chromedriver().setup();
ChromeOptions options = new ChromeOptions();
options.addArguments("--ignore-certificate-errors");
driver = new ChromeDriver(options);

我已将其用于Java和Chrome浏览器,效果很好

答案 16 :(得分:0)

创建配置文件,然后创建驱动程序有助于我们解决Firefox中的证书问题:

var profile = new FirefoxProfile();
profile.SetPreference("network.automatic-ntlm-auth.trusted-uris","DESIREDURL");
driver = new FirefoxDriver(profile);

答案 17 :(得分:0)

对于 .NET,对我有用的是以下...

var chromeOptions = new ChromeOptions { AcceptInsecureCertificates = true };

基本上,它告诉 ChromeDriver 选项在检测到不安全证书时不要停止浏览器执行,并照常进行。

答案 18 :(得分:-2)

看起来它仍然没有这个问题的标准决定。换句话说 - 你仍然不能说“好吧,做一个认证,无论你是Internet Explorer,Mozilla还是谷歌Chrome”。但是我发现了一篇帖子,展示了如何解决Mozilla Firefox中的问题。如果您对此感兴趣,可以查看here