gpt4 book ai didi

webdriver - 我们怎样才能让 Watir-Webdriver 与 IE 无效证书屏幕一起工作?

转载 作者:行者123 更新时间:2023-12-01 12:58:39 25 4
gpt4 key购买 nike

我们在测试时可能都见过这个屏幕,你只需要一个带有自签名证书的 HTTPS 站点,你就会看到“这个网站的安全证书有问题”屏幕,这需要你点击一个链接继续。

对于 Watir,这没问题,我可以像处理任何其他网页一样自动显示屏幕,根据其文本或 ID 值单击链接。

使用 Watir-Webdriver 就好像 HTML 中的任何内容都无法识别。我并不孤单 See this question

不仅仅是尝试点击一个链接,几乎任何你在这里尝试的操作都会在这个页面上失败,即使是一个简单的函数,比如 puts browser.text 也会返回一个错误。

Selenium::WebDriver::Error::NoSuchElementError: Unable to find element with tag name == body

您可以查看源代码、使用开发人员工具,或者让浏览器元素吐出它的 HTML,然后清楚地看到该死的 body 标签就在那里,但 Webdriver 出于某种原因对它视而不见。

我不知道这是线索还是转移注意力,但我知道 webdriver 在后台使用了大量的 XPATH,而且我相信 XPATH 区分大小写。在这方面,当我对这个页面使用 puts browser.html 时,我看到了一些非常不寻常的东西,因为每个标签名称都是全大写的。在任何情况下都有些不寻常但合法有效的 HTML。在其他页面上使用 browser.html 显示小写标签。这可能是导致 webdriver 在此页面上出现如此多问题的原因吗?

关于如何让 webdriver 看到链接元素以便我可以单击它,有没有人有什么好主意?

当我请求页面 HTML 时浏览器对象的输出

irb(main):019:0> puts $browser.html  #note, indentation is added later for clarity
<HTML dir=ltr>
<HEAD>
<TITLE>Certificate Error: Navigation Blocked</TITLE>
<LINK rel=stylesheet type=text/css href="ErrorPageTemplate.css">
<META name=MS.LOCALE content=EN-US>
<META content="text/html; charset=utf-8" http-equiv=Content-Type>
<META content=Yes http-equiv=MSThemeCompatible>
<SCRIPT language=javascript type=text/javascript src="errorPageStrings.js">
</SCRIPT>
<SCRIPT language=javascript type=text/javascript src="httpErrorPagesScripts.js">
</SCRIPT>
<SCRIPT language=javascript type=text/javascript src="invalidcert.js">
</SCRIPT>
</HEAD>
<BODY onload="BodyLoad(); initMoreInfo('infoBlockID');" class=securityError>
<TABLE border=0 cellSpacing=0 cellPadding=0 width=730>
<!-- Main title -->
<TBODY>
<TR>
<TD id=shieldIconAlign vAlign=top rowSpan=3 width=60 align=left>
<IMG id=shieldIcon alt="Shield icon" src="red_shield_48.png">
</TD>
<TD id=mainTitleAlign vAlign=middle align=left>
<H1 id=mainTitle>There is a problem with this website's security certificate</H1>
</TD>
</TR>
<TR>
<TD>
<H3>
<DIV id=linkdiv name="linkdiv"></DIV>
</H3>
</TD>
</TR>
<TR>
<!-- This row is for the the divider-->
<TD id=errorCodeAlign class=errorCodeAndDivider align=right>&nbsp;
<DIV class=divider></DIV>
</TD>
</TR>
<!-- Error Body -->
<TR>
<TD></TD>
<TD>
<H3>
<DIV style="DISPLAY: block" id=CertUnknownCA name="CertUnknownCA">
The security certificate presented by this website was not issued by a trusted certificate authority.
</DIV>
<DIV style="DISPLAY: none" id=CertExpired name="CertExpired"></DIV>
<DIV style="DISPLAY: none" id=CertCNMismatch name="CertCNMismatch"></DIV>
<DIV style="DISPLAY: none" id=CertRevoked name="CertRevoked"></DIV>
<NOSCRIPT id=securityCert1></NOSCRIPT><BR>
<ID id=securityCert2>
Security certificate problems may indicate an attempt to fool you or intercept any data you send to the server.
</ID>
</H3>
</TD>
</TR>
<!-- Recommendation-->
<TR>
<TD>&nbsp;</TD>
<TD><H2 id=recommendation><B>We recommend that you close this webpage and do not continue to this website. </B></H2></TD>
</TR>
<!-- close webpage-->
<TR>
<TD>&nbsp;</TD>
<TD id=closeWebpageAlign vAlign=middle align=left>
<H4 id=closeWebpage>
<IMG class=actionIcon border=0 alt="Recommended icon" src="green_shield.png">
<A href="javascript:closePage()">Click here to close this webpage.</A>
</H4>
</TD>
</TR>
<!-- continue to site-->
<TR>
<TD>&nbsp;</TD>
<TD id=continueToSiteAlign vAlign=middle align=left>
<H4 id=continueToSite>
<IMG id=ImgOverride class=actionIcon border=0 alt="Not recommended icon" src="red_shield.png">
<A id=overridelink href="http://admanager.qa-prod.local/signups/lead_form" name=overridelink>Continue to this website (not recommended).</A>
</H4>
</TD>
</TR>
<!-- InfoBlock -->
<TR>
<TD id=infoBlockAlign vAlign=top align=right>&nbsp; </TD>
<TD id=moreInformationAlign vAlign=middle align=left>
<H4>
<TABLE>
<TBODY>
<TR>
<TD vAlign=top>
<A onclick="javascript:expandCollapse('infoBlockID', true); return false;" href="#">
<IMG id=infoBlockIDImage class=actionIcon border=0 alt="More information" src="down.png">
</A>
</TD>
<TD vAlign=top>
<SPAN id=moreInfoContainer>
<A href="javascript:expandCollapse('infoBlockID', true);">More information</A>
</SPAN>
<NOSCRIPT></NOSCRIPT>
</TD>
</TR>
</TBODY>
</TABLE>
</H4>
<DIV style="DISPLAY: none" id=infoBlockID class=infoBlock>
<P>
<LI id=errorExpl1>If you arrived at this page by clicking a link, check the website address in the address bar to be sure that it is the address you were expecting.
<LI id=errorExpl2>When going to a website with an address such as https://example.com, try adding the 'www' to the address, https://www.example.com.
<P></P>
<P id=moreInfoSeeHelpPF>For more information, see "Certificate Errors" in Internet Explorer Help.
</P>
</LI>
</DIV>
</TD>
</TR>
</TBODY>
</TABLE>
</BODY>
</HTML>
=> nil
irb(main):020:0>

最佳答案

我做了一些实验,包括使用我发布的 HTML 创建我自己的页面,没有任何 JavaScript。如果我使用该页面,我会发现它会阻止 JavaScript 操作。在这种情况下,当我尝试执行诸如 browser.text 或 browser.link.exists? 之类的操作时,我会看到一个 IE 警告弹出窗口,告诉我 IE 正在阻止 JS 在该页面上工作。 (我从未在实际的证书错误页面上看到过)在 watir-webdriver 中,我得到了与我报告的相同的错误。如果我单击允许 JS 的选项,那么我可以在 watir-webdriver 中使用该页面。

因此,页面的本质似乎阻止了任何阻止 Webdriver 访问页面的 JS 级自动化。

我明白 MS 这样做的原因,他们不希望虚假网站以某种方式使用 JavaScript 来绕过该警告。显然,Watir 驱动事物的方式(通过 OLE?)不被视为您可以远程执行的操作,因此允许访问该页面。

然后解决方案是将 Watir 用于您的 IE 自动化,或者使证书受信任,这样您就不会看到警告。

如果您想使用 Watir-Webdriver,则需要将测试服务器上使用的证书添加到受信任的根证书颁发机构存储中。注意不是默认的“个人”商店!添加证书时,您需要更改放置证书的位置,或者您基本上只为该 session 授权做一次。将出现一条警告,表明现在来自该权威机构的所有证书都将受到信任。我会非常小心地使用它,仅在测试系统上使用,并且仅用于信任来自您自己的内部测试服务器的证书。

通过双击提醒您证书无效的红色警告,手动进入页面后很容易做到这一点。如果您做对了,您可以关闭浏览器,重新打开,进行导航,而不会出现错误。

关于webdriver - 我们怎样才能让 Watir-Webdriver 与 IE 无效证书屏幕一起工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8101700/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com