openssl s_client 使用代理

Posted

技术标签:

【中文标题】openssl s_client 使用代理【英文标题】:openssl s_client using a proxy 【发布时间】:2011-03-14 07:42:25 【问题描述】:
openssl s_client -connect some.https.server:443 -showcerts

当您想要检查服务器的证书及其证书链时,这是一个很好的运行命令。

当您使用 HTTP/HTTPS 代理时,有没有办法运行此命令?

【问题讨论】:

【参考方案1】:

官方没有。

但这里有一个补丁:http://rt.openssl.org/Ticket/Display.html?id=2651&user=guest&pass=guest

【讨论】:

实际上,截至 2015 年 5 月 22 日,该补丁似乎已实际实施。我也看到了【参考方案2】:

你可以使用proxytunnel:

proxytunnel -p yourproxy:8080 -d www.google.com:443 -a 7000

然后你可以这样做:

openssl s_client -connect localhost:7000 -showcerts

希望对你有帮助!

【讨论】:

我必须让proxytunnel -p yourproxy:8080 -d www.google.com:443 -a 7000 在后台运行以释放终端以执行第二个命令。 proxytunnel 支持代理身份验证,(afaict)openssl s_client -proxy 不支持,至少在 1.1.0h 中不支持。【参考方案3】:

对于 2015 年 5 月后来到这里的任何人:有一个新的“-proxy”选项将包含在下一个版本的 openssl 中:https://rt.openssl.org/Ticket/Display.html?id=2651&user=guest&pass=guest

【讨论】:

我刚刚在 2016 年 3 月 1 日尝试了 OpenSSL 1.0.2g (Windows),它对代理选项一无所知。为什么? 是否可以将 openssl 包更新为未与操作系统捆绑的版本? @ChristianSchäfer 这是因为 1.0.2xx 版本不是“下一个版本”。此选项仅在 OpenSSL 1.1.0xx 及更高版本中可用。 确实,见手册页openssl.org/docs/man1.1.0/apps/openssl-s_client.html#OPTIONS【参考方案4】:

从 openssl v1.1.0 开始

C:\openssl>openssl version
OpenSSL 1.1.0g  2 Nov 2017
C:\openssl>openssl s_client -proxy 192.168.103.115:3128 -connect www.google.com -CAfile C:\TEMP\internalCA.crt
CONNECTED(00000088)
depth=2 DC = com, DC = xxxx, CN = xxxx CA interne
verify return:1
depth=1 C = FR, L = CROIX, CN = svproxysg1, emailAddress = xxxx@xxxx.xx
verify return:1
depth=0 C = US, ST = California, L = Mountain View, O = Google Inc, CN = www.google.com
verify return:1
---
Certificate chain
 0 s:/C=US/ST=California/L=Mountain View/O=Google Inc/CN=www.google.com
   i:/C=xxxx/L=xxxx/CN=svproxysg1/emailAddress=xxxx@xxxx.xx
 1 s:/C=xxxx/L=xxxx/CN=svproxysg1/emailAddress=xxxx@xxxx.xx
   i:/DC=com/DC=xxxxx/CN=xxxxx CA interne
---
Server certificate
-----BEGIN CERTIFICATE-----
MIIDkTCCAnmgAwIBAgIJAIv4/hQAAAAAMA0GCSqGSIb3DQEBCwUAMFIxCzAJBgNV
BAYTAkZSMQ4wDAYDVQQHEwVDUk9JWDETMBEGA1UEAxMKc3Zwcm94eXNnMTEeMBwG

【讨论】:

已下载 1.1.1 源代码,尝试过此语法。工作完美。干杯。 谢谢,我没有注意到-proxy 选项,但我想知道是否应该考虑代理环境变量。 Raul,我在源代码中没有找到“http_proxy”,所以我可以考虑不支持代理环境变量【参考方案5】:

即使使用 openssl v1.1.0 我在通过代理时也遇到了一些问题,例如s_client: HTTP CONNECT failed: 400 Bad Request 这迫使我编写了一个最小的 Java 类来显示 SSL 握手

    public static void main(String[] args) throws IOException, URISyntaxException 
    HttpHost proxy = new HttpHost("proxy.my.company", 8080);
    DefaultProxyRoutePlanner routePlanner = new DefaultProxyRoutePlanner(proxy);
    CloseableHttpClient httpclient = HttpClients.custom()
            .setRoutePlanner(routePlanner)
            .build();
    URI uri = new URIBuilder()
            .setScheme("https")
            .setHost("www.myhost.com")
            .build();
    HttpGet httpget = new HttpGet(uri);
    httpclient.execute(httpget);

具有以下依赖关系:

    <dependency>
        <groupId>org.apache.httpcomponents</groupId>
        <artifactId>httpclient</artifactId>
        <version>4.5.2</version>
        <type>jar</type>
    </dependency>

你可以用Java SSL Logging turned on运行它

这应该会产生不错的输出,例如

trustStore provider is :
init truststore
adding as trusted cert:
  Subject: CN=Equifax Secure Global eBusiness CA-1, O=Equifax Secure Inc., C=US
  Issuer:  CN=Equifax Secure Global eBusiness CA-1, O=Equifax Secure Inc., C=US
  Algorithm: RSA; Serial number: 0xc3517
  Valid from Mon Jun 21 06:00:00 CEST 1999 until Mon Jun 22 06:00:00 CEST 2020

adding as trusted cert:
  Subject: CN=SecureTrust CA, O=SecureTrust Corporation, C=US
  Issuer:  CN=SecureTrust CA, O=SecureTrust Corporation, C=US
(....)

【讨论】:

以上是关于openssl s_client 使用代理的主要内容,如果未能解决你的问题,请参考以下文章

将“-servername”参数与 openssl s_client 一起使用

如何在连接后终止 OpenSSL s_client

SSL/TLS深度解析--OpenSSL s_client测试子命令

使用套接字与 XML API openssl s_client -connect 与 Java 通信

OpenSSL s_client测试子命令

使用openssl校验证书链