当前位置: 首页 > 面试题库 >

Webdriver-HTTP身份验证对话框

谭云瀚
2023-03-14
问题内容

我有一个非常简单的selenium-webdriver脚本。我想使用webdriver进行HTTP身份验证。

脚本:

WebDriver driver = new FirefoxDriver();  
driver.get("http://www.httpwatch.com/httpgallery/authentication/");
driver.findElement(By.id("displayImage")).click();
Thread.sleep(2000);
driver.switchTo().alert().sendKeys("httpwatch");

问题:

driver.switchTo().alert().sendKeys("httpwatch");

抛出

org.openqa.selenium.NoAlertPresentException:不存在警报

题:

  • Webdriver是否仅找到警报对话框作为警报?
  • 在不使用AutoIt或http:// username:password @somesite的情况下,可以执行哪些自动化操作?

编辑

警报具有以下方法,但尚未实施。

driver.switchTo().alert().authenticateUsing(new UsernameAndPassword("username","password"))

问题答案:

问题在于 这不是javascript弹出窗口, 因此您无法通过selenium的对其进行操作alert()

如果AutoIt和URL中的提交凭据(最简单的选项-仅打开url,然后单击“显示图像”)都不适合您,则另一种方法是使用AutoAuthfirefox插件自动提交以前保存的凭据:

当您选择让浏览器保存登录信息时,AutoAuth会自动提交HTTP身份验证对话框。(如果您已经告诉浏览器您的用户名和密码,并且告诉它记住该用户名和密码,为什么不让它自动提交而不是每次都询问您呢?)

遵循Firefox中通过URL进行的HTTP BasicAuth中、建议的答案[、不起作用?、线:

  • 安装AutoAuth Firefox插件;
  • 访问需要身份验证的站点。输入您的用户名和密码,并确保选择保存凭据;
  • 将AutoAuth安装html" target="_blank">文件保存在硬盘上:在插件页面上,右键单击“添加到Firefox”和“将链接另存为”;
  • 实例化Firefox webdriver,如下所示:

FirefoxProfile firefoxProfile = new ProfilesIni().getProfile("default");
File pluginAutoAuth = new File("src/test/resources/autoauth-2.1-fx+fn.xpi");
firefoxProfile.addExtension(pluginAutoAuth);
driver = new FirefoxDriver(firefoxProfile);

此外,以类似于AutoIt选项的方式-
您可以使用sikuli屏幕识别和自动化工具在弹出窗口中提交凭据。

另请参阅其他想法和选项:

  • 支持BASIC和摘要HTTP身份验证
  • 使用Selenium处理浏览器级别的身份验证


 类似资料:
  • 问题内容: 我有一个非常简单的selenium-webdriver脚本。我想使用webdriver进行HTTP身份验证。 脚本: 问题: 抛出 org.openqa.selenium.NoAlertPresentException:不存在警报 题: Webdriver是否仅找到警报对话框作为警报? 在不使用AutoIt或http:// username:password @somesite的情况下

  • 在浏览器中直接键入下面的url,它可以工作, 但是,当我使用相同的url,用于selenium网络驱动程序测试时,它连接到 以及请求HTTP身份验证。我是否需要更改chrome浏览器中的任何设置,或调整默认配置文件?

  • 我们试图在本地模式下使用BrowserStack在内部网络上点击AUT。我已经对其进行了配置,以便获得远程浏览器会话,但当我试图通过Chrome将其定向到我们的应用程序(或防火墙内的任何)URL时,浏览器会弹出一个对话框,抱怨连接不是私有的,并要求输入用户名和密码。这不是一个正常的弹出窗口,我们无法使用Selenium自动执行,因此它会阻止我们死亡。 通过桌面浏览器会话访问时,系统知道我是谁,并以

  • 问题内容: 因为在AngularJS中使用CORS和http身份验证可能会比较棘手,所以我编辑了问题以分享一个经验教训。首先,我要感谢igorzg。他的回答对我很有帮助。场景如下:您想使用AngularJS $ http服务将POST请求发送到另一个域。获取AngularJS和服务器设置时,需要注意一些棘手的事情。 第一:在您的应用程序配置中,您必须允许跨域调用 第二:您必须指定withCrede

  • keytool-list-v-keystore my_keystore.jks

  • 问题内容: 因此,我正在使用RESTeasy和Google App Engine开发REST Web服务。我的问题与GAE无关,但我提到它只是为了以防万一。碰巧的是,我自然需要保护自己的资源和我自己的用户(而不是Google的用户)。 REST Web服务的安全似乎是一个很有争议的主题,或者至少是一个非常“自由的”主题。REST对此没有施加任何标准。根据我在网络和文献上的研究,至少有3种方法适合我