AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 917333
Accepted
Kevin Buchs
Kevin Buchs
Asked: 2018-06-20 08:53:10 +0800 CST2018-06-20 08:53:10 +0800 CST 2018-06-20 08:53:10 +0800 CST

在 TLS 证书和 MacOS 上寻求基本事实 - 比较浏览器、curl、openssl

  • 772

在 Mac,High Sierra 10.13.5 上,我发现 TLS 认证验证有所不同。访问https://www.visitflorida.com时,Chrome 和 Safari 对 TLS 验证感到满意。此外,curl 没有任何抱怨,我没有使用“-k”。但是,openssl 抱怨它在尝试 this 时找不到中间证书openssl s_client -connect www.visitflorida.com:443 < /dev/null | openssl x509 -subject -noout。我已经使用了基本的 openssl 和 brew-installed 一个。

我试图添加 -CAfile intermediate.pem(我从 TrustWave 下载了中间证书)。即使中间证书没有出现在我的 KeyChain 中的任何位置,我也已将我的 KeyChain System Roots 导出到一个文件中,并通过 -CAfile 进行了尝试。没有任何工作。我看到证书的唯一文件系统位置是 /etc/ssl/cert.pem,当我通过 -CAfile 指定它时,它仍然失败。

有人建议我的浏览器和 curl 对 TLS 验证的要求比 openssl 更宽松。真的是这样吗?我很难相信。谁能帮我解释这种行为?

顺便说一句,我知道这可以通过在 www.visitflorida.com 的 TLS 端点上包含中间证书和端点证书来解决。现在,如果我们能找到那个丢失的密钥文件!

浏览器快乐:浏览器验证截图

卷曲日志:卷曲输出

ssl-certificate
  • 1 1 个回答
  • 476 Views

1 个回答

  • Voted
  1. Best Answer
    garethTheRed
    2018-06-20T09:38:02+08:002018-06-20T09:38:02+08:00

    浏览器,如 Internet Explorer/Edge、Chrome 和 Safari,将查看 AIA 扩展的 caIssuer 字段以获取 URL,如果在 TLS 握手期间服务器未提供高级 CA 证书,它可以从该 URL 下载高级 CA 证书。

    您网站的证书有一个 caIssuer 字段设置为http://ssl.trustwave.com/issuers/OVCA2_L1.crt因此上述所有浏览器将从该 URL 下载它并使用它来构建链。

    OpenSSL 等命令行工具s_client不会使用 caIssuer 下载此附加证书,因此您目睹了这种情况。如果您要尝试 Mozilla Firefox,您也会注意到同样的情况,因为 Mozilla 拒绝使用此扩展程序。

    caIssuer 字段最终掩盖了真正的问题,即糟糕的服务器管理员。 RFC 5246 第 7.4.2 节规定服务器必须发送certificate_list由其自己的证书和任何中间 CA 证书组成的证书。

    • 3

相关问题

  • RHEL/Apache ssl.conf 配置问题

  • IIS7 中的证书信任列表

  • SSL证书的区别?

  • 如何修复邮件服务器 SSL?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve