如何使用rust-openssl创建与`-starttls smtp`等效的连接?

时间:2018-11-12 16:42:59

标签: openssl rust smtp starttls

当我在终端中运行以下命令时

openssl s_client -connect gmail-smtp-in.l.google.com:25 -starttls smtp

我收到CONNECTED(00000005)的回复。

我正在尝试使用rust-openssl与Rust进行相同的连接(尽管我对其他库开放),这就是我所拥有的:

extern crate openssl;

use openssl::ssl::{SslConnector, SslMethod};

use std::net::TcpStream;

fn main() {
    let connector = SslConnector::builder(SslMethod::tls()).unwrap().build();
    let stream = TcpStream::connect("gmail-smtp-in.l.google.com:25").unwrap();
    let e = connector
        .connect("gmail-smtp-in.l.google.com", stream)
        .unwrap_err();
    eprintln!("{:#?}", e);
}

但是,我得到的答复是:

Failure(
    MidHandshakeSslStream {
        stream: SslStream {
            stream: TcpStream {
                addr: V6(
                    [2001:41d0:a:2346::1]:57190
                ),
                peer: V6(
                    [2a00:1450:400c:c0c::1b]:25
                ),
                fd: 3
            },
            ssl: Ssl {
                state: "SSLv3/TLS write client hello",
                verify_result: X509VerifyResult {
                    code: 0,
                    error: "ok"
                }
            }
        },
        error: Error {
            code: ErrorCode(
                1
            ),
            cause: Some(
                Ssl(
                    ErrorStack(
                        [
                            Error {
                                code: 336130315,
                                library: "SSL routines",
                                function: "ssl3_get_record",
                                reason: "wrong version number",
                                file: "ssl/record/ssl3_record.c",
                                line: 252
                            }
                        ]
                    )
                )
            )
        }
    }
)

我猜我在Rust代码中缺少-starttls smtp部分,但无法弄清楚如何添加它。

1 个答案:

答案 0 :(得分:0)

在openssl-sources中更详细地了解console.log()的实际功能,然后在Rust中重播它?这只是几个库调用,但是首先您需要对服务器说出STMP,然后然后切换到TLS。 (也许已经在一个调用中将其捆绑在openssl库中。)