我的网络上的服务器使用RapidSSL CA颁发的证书进行签名,但不提供给完整的发行者链(RapidSSL CA的证书由GeoTrust CA颁发,这是一个受信任的根权限).

当我使用Firefox访问该网站时,我收到以下错误:

The certificate is not trusted because no issuer chain was provided.
(Error code: sec_error_unkNown_issuer)

但是,如果我使用IE或Chrome连接到网站,它可以工作,我注意到RapidSSL随后被加载为中级CA.我不明白Chrome / IE(我假设它使用Windows证书存储区)知道如何将RapidSSL添加为中间CA.

当我使用openssl s_client来调试连接时,我得到了预期的行为(根据我的说法).

仅使用GeoTrust作为CA时,我得到以下内容:

Verify return code: 21 (unable to verify the first certificate)

仅使用RapidSSL作为CA:

Verify return code: 2 (unable to get issuer certificate)

使用时:

Verify return code: 0 (ok)

任何人都可以帮助我理解Windows如何将RapidSSL CA作为中间权限加载?

根据颁发的证书的授权信息访问(AIA)扩展中的URL信息下载CA证书.

我听说,Firefox使用自己的证书存储和/或链接引擎. Chrome和IE使用Windows中的一个.

证书验证过程

将证书提交给应用程序时,应用程序必须使用证书链引擎来确定证书的有效性.只有在证书链成功验证后,应用程序才能信任证书和证书所代表的身份.三个不同但相互关联的过程用于确定证书的有效性:

■证书发现要构建证书链,证书链引擎必须收集颁发CA证书和所有CA证书,直至根CA证书. CA证书是从CryptoAPI缓存,组策略或企业策略中收集的,或者作为最后的手段,从颁发的证书中的授权信息访问(AIA)统一资源定位符(URL)下载.从CryptoAPI缓存以外的位置下载证书后,会将其添加到用户的CryptoAPI缓存中,以便更快地进行检索.

■路径验证当证书链引擎验证证书时,它会执行不要停留在提供的证书上.证书链中的每个证书都必须是验证,直到达到自签名根证书.验证测试可以包括验证authenticode签名,确定颁发CA证书是否包含在NTAuth存储中,或包含特定的应用程序或证书策略对象标识符(OID).如果一个证书未通过有效性测试,则整个链可能被视为无效并且未被调用应用程序使用.

windows – IE / Chrome如何知道哪些中级CA在不属于链时使用?的更多相关文章

  1. iOS Chrome上的HTML SELECT不显示“完成”选项

    我们在iOS上的Chrome中使用UI呈现时遇到问题,特别是HTMLSELECTDropDown元素.例:使用Safari,当您点击SELECT时,屏幕底部会打开一个微调器–您可以点击完成以选择您的选择并返回到表单.但是,当您在iOS上的Chrome中加载完全相同的页面时,不会显示“完成”.用户必须选择他们的选择,然后点击UI上的其他位置返回到表单.非常不直观,用户感觉好像SELECT没有用.有人有解决方案吗?

  2. 有任何方法可以在任何IOS设备中调试chrome

    有没有办法在IOS设备上调试Chrome浏览器?如果没有办法,我可以如何处理ios上的chrome错误?

  3. ios – 为什么Google Chrome模拟器以375×667的分辨率显示iPhone 6?

    我正在以编程方式调整我的网站的图像尺寸不同大小的设备.但现在我无法告诉我实际需要什么尺寸.在GoogleChrome模拟器中,我看到我的某些图像有所增加,例如在iPhone6从230×230自然到357×357显示.该图像几乎占据了仿真屏幕的整个宽度,并且看起来稍微退化,这表明iPhone6的宽度不会大于357像素.但是ApplesaysiPhone6的分辨率是750×1334!为什么某些来源的供应尺寸是Chrome模拟器所说的两倍?

  4. android – 使用Dart进行远程调试

    这个问题的动机是,我花了大约两个小时来找出我做错了什么.如何在我的Android手机或模拟器上远程调试我的Dart-Webapp?

  5. Android深层链接仅适用于某些网站

    我在我的应用程序中使用应用程序索引,但有时它无法正确接收来自Chrome的意图.如果我从我的生产网站打开链接,它将由chrome打开.所以我创建了一个具有相同代码的测试站点.但是,在这种情况下,我的应用程序正确打开深层链接.我找不到任何解释,因为它在网络中使用相同的代码(但在不同的网站中)和相同的Android应用程序.这是我的意图过滤器:这是我的按钮中的HTML代码:如果我打开此地址(制作)中的

  6. 如何在android上使用selenium或appium自动化Chrome浏览器?

    我想在Android设备上自动化AndroidChrome浏览器(不只是webview或其他浏览器,而是Chrome浏览器).我认为这可以通过这个链接https://sites.google.com/a/chromium.org/chromedriver/getting-started/getting-started—android,但它自动化我的PC浏览器浏览器.我也试过Appium,但日志后没

  7. 如何在Android模拟器上运行适用于Android 4的新Chrome?

    AndroidEmulator开发人员何时能够在新发布的Android版Chrome中进行测试和开发?解决方法来自deejoy的回复于http://blog.apkudo.com/2012/08/08/run-google-play-on-an-emulator-and-pretend-to-be-any-device/…我确实设法在我的模拟器上下载并安装了最新的chrome.但是,当我在模拟器上运行Chrome时遇到以下错误:那么,这意味着什么?q=context_group.cc&origq=cont

  8. android – 如何检查Chrome是否支持Chrome自定义标签?

    像这样我假设:解决方法您可以使用PackageManager检查是否支持自定义选项卡,而不是绑定和解除绑定服务.请注意,其他浏览器将来可能会支持自定义标签,因此您可能需要修改它以支持此案例.

  9. android – 在Chrome自定义标签中停用Cookie并清除缓存

    我正在使用Chrome自定义标签将用户重定向到第三方网站的链接.但是,我希望在生成的Chrome自定义标签中禁用Cookie并清除缓存.我搜索了文档,但找不到实现此目的的方法.请帮助解决方法Chrome自定义标签与常规Chrome共享Cookie.如果您不希望共享cookie和/或希望控制缓存,请考虑使用WebView,它在您自己的流程中运行,并且不与Chrome共享任何数据.

  10. android – WebView与Chrome自定义标签

    我正在构建一个应用程序,在详细活动中我必须显示一个网页.我打算使用WebView,但后来我看到了ChromeCustomTab.你们认为最好实施什么?解决方法如果您只是想显示某个页面,那么我建议您使用chrome自定义标签.您可以按照类似于您的应用程序样式的方式设置工具栏的样式,它们用于显示内容,而您不必担心其他任何事情.如果您想完全控制用户在本网站内所做的事情,您必须使用webview.(你可以阻止用户点击webview上的链接,你可以拦截用户输入网站控件的数据……

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部