web-dev-qa-db-ja.com

Roundcube&Postfix SMTP:SSLルーチン:SSL3_READ_BYTES:tlsv1アラート不明ca:s3_pkt.c

Postfix/Dovecot/Roundcubeの設定を個人的に使用し、他のユーザーに提供しています。このセットアップ全体を新しいボックスに転送しようとしていますが、いくつか問題があります。

メールの受信は正常に機能しています(内部でのみテストされ、ドメインはまだ転送されていません)。また、TLS/SSL(Thunderbirdなど)を使用して外部のIMAPおよびSMTPが正常に機能しています。

問題は、127.0.0.1までのIMAPを使用でき、ユーザーの電子メールを見事に表示できるが、単純に次のように主張するだけで電子メールを送信できないラウンドキューブのセットアップにあります:"SMTP Error (220): Authentication failed."

奇妙なことに、現在のサーバーで使用していたものと同じPostfix/Dovecot構成では、Roundcubeは新しいサーバーではアクセスできなくなりました。関連するラウンドキューブ構成は次のとおりです。

$config['smtp_server'] = 'tls://localhost';

// Log SMTP conversation to <log_dir>/smtp or to syslog
$config['smtp_debug'] = true;

// SMTP port (default is 25; use 587 for STARTTLS or 465 for the
// deprecated SSL over SMTP (aka SMTPS))
$config['smtp_port'] = 587;

// SMTP username (if required) if you use %u as the username Roundcube
// will use the current username for login
$config['smtp_user'] = '%u';

// SMTP password (if required) if you use %p as the password Roundcube
// will use the current user's password for login
$config['smtp_pass'] = '%p';

Roundcubeのログ/エラーログは、単に次のように述べています。

[02-Jan-2015 16:55:49 America/New_York] STARTTLS failed (): 
[02-Jan-2015 16:55:49 -0500]: SMTP Error: SMTP error: Authentication failure: STARTTLS failed (Code: ) in /var/wwwmail/program/lib/Roundcube/rcube.php on line 1505 (POST /?_task=mail&_unlock=loading1420235752730&_lang=undefined&_framed=1?_task=mail&_action=send)

Roundcubeのlogs/smtpログは次のように表示します。

[02-Jan-2015 17:50:01 -0500]: Recv: 220 example.net ESMTP Postfix
[02-Jan-2015 17:50:01 -0500]: Send: EHLO example.net
[02-Jan-2015 17:50:01 -0500]: Recv: 250-example.net
[02-Jan-2015 17:50:01 -0500]: Recv: 250-PIPELINING
[02-Jan-2015 17:50:01 -0500]: Recv: 250-SIZE 104857600
[02-Jan-2015 17:50:01 -0500]: Recv: 250-VRFY
[02-Jan-2015 17:50:01 -0500]: Recv: 250-ETRN
[02-Jan-2015 17:50:01 -0500]: Recv: 250-STARTTLS
[02-Jan-2015 17:50:01 -0500]: Recv: 250-ENHANCEDSTATUSCODES
[02-Jan-2015 17:50:01 -0500]: Recv: 250-8BITMIME
[02-Jan-2015 17:50:01 -0500]: Recv: 250 DSN
[02-Jan-2015 17:50:01 -0500]: Send: STARTTLS
[02-Jan-2015 17:50:01 -0500]: Recv: 220 2.0.0 Ready to start TLS
[02-Jan-2015 17:50:01 -0500]: Send: RSET
[02-Jan-2015 17:50:01 -0500]: Recv: M I A…"qhçR¸
[02-Jan-2015 17:50:01 -0500]: Send: QUIT

/etc/postfix/main.cfからの私のpostfix設定の関連するスニペットは次のとおりです

# TLS parameters for SMTP service
smtpd_tls_security_level    = may
smtpd_tls_cert_file         = /etc/ssl/private/example.net/example.net.crt
smtpd_tls_key_file          = /etc/ssl/private/example.net/example.net.key
smtpd_tls_auth_only         = yes

/etc/postfix/master.cfからの私のpostfix設定の関連スニペットは次のとおりです

smtp      inet  n       -       -       -       -       smtpd
  -o content_filter=spamassassin
submission inet  n       -       n       -       -       smtpd
  -o syslog_name=postfix/submission
  -o smtpd_tls_security_level=encrypt
  -o smtpd_sasl_auth_enable=yes
  -o cleanup_service_name=cleanup_submit
smtps     inet  n       -       -       -       -       smtpd
  -o content_filter=spamassassin
  -o syslog_name=postfix/smtps
  -o smtpd_tls_wrappermode=yes
  -o smtpd_sasl_auth_enable=yes
  -o smtpd_client_restrictions=permit_sasl_authenticated,reject
  -o milter_macro_daemon_name=ORIGINATING

Postfixログ/var/log/mail.logは次のエラーを報告します。

Jan  2 17:50:01 example postfix/submission/smtpd[19959]: connect from localhost.localdomain[127.0.0.1]
Jan  2 17:50:01 example postfix/submission/smtpd[19959]: SSL_accept error from localhost.localdomain[127.0.0.1]: 0
Jan  2 17:50:01 example postfix/submission/smtpd[19959]: warning: TLS library problem: error:14094418:SSL routines:SSL3_READ_BYTES:tlsv1 alert unknown ca:s3_pkt.c:1292:SSL alert number 48:
Jan  2 17:50:01 example postfix/submission/smtpd[19959]: lost connection after STARTTLS from localhost.localdomain[127.0.0.1]
Jan  2 17:50:01 example postfix/submission/smtpd[19959]: disconnect from localhost.localdomain[127.0.0.1]

私は同様のエラーコードでいくつかの他の質問を読みましたが、それらはすべて自己署名証明書を使用しているようです、または / etc/ssl/certs /からの証明書のハッシュへのリンクを追加 、誤解しているかもしれませんが、間違った証明書をリンクしました。

Roundcubeが1.0.4にアップデートされました。これにより、opensslによるphpバージョンの非互換性の問題が修正されました。私はすべてアイデアがなくなった、誰にもアイデアはありますか?

10
1n5aN1aC

上記のエラーメッセージはクライアントのように見えます(roundcubeによって呼び出されたPHPスクリプト) 不明なCAのためピア証明書の検証に失敗します 。このエラーが発生した理由はたくさんあります。

Opensslについては、Roundcubeバージョン1.0-RC以降にSSL接続オプションが付属しています。パラメータsmtp_conn_optionsおよびimap_conn_optionsは、バージョン1.0-RCおよび1.0.3でそれぞれ追加されました。デフォルトでは、両方のパラメーターの値はnullでした。以下のスニペットは、ラウンドキューブファイルconfig/defaults.inc.phpPHPマニュアル を参照して、このパラメーターの完全な説明を取得できます。

// SMTP socket context options
// See http://php.net/manual/en/context.ssl.php
// The example below enables server certificate validation, and
// requires 'smtp_timeout' to be non zero.
// $config['smtp_conn_options'] = array(
//   'ssl'         => array(
//     'verify_peer'  => true,
//     'verify_depth' => 3,
//     'cafile'       => '/etc/openssl/certs/ca.crt',
//   ),
// );
$config['smtp_conn_options'] = null;

自己署名証明書を使用する多くのシステムでは、デフォルト値がPHP 5.5以前で機能します。デフォルトでは、 PHP 5.6はインストールされたCAに対してピア証明書を検証し、ピア名を検証します

現在、Debian jessieのようにも見えます デフォルトで出荷PHPバージョン5.6 。どうやらPHPはpostfix証明書の検証に失敗します。 、PHP verify_peer_name(ホスト名にlocalhostを指定したため)またはverify_peer(CAが不明だったため)で失敗します


同様のケースも起こりました Arch Linuxユーザーに対して 。解決策は次のいずれかです。

  • Openssl certディレクトリにCA証明書をインストールします
  • Roundcube smtp_serverオプションで、localhostをPostfix FQDNに変更(OPからのソリューション)
  • Smtp_conn_optionsのverify_peerやverify_peer_nameを無効にします
11
masegaloeh

PHP 5.6はSSLピア検証を行います。つまり、既知のCAであるかどうかにかかわらず、SMTPサーバーの証明書をチェックします。

Smtp_serverオプションは、証明書のCNフィールドと一致する必要があります! (一般名)

そのため、そこにlocalhostを配置しないでください。証明書に一致する完全修飾ドメイン名をそこに配置してください。

クレジット: https://www.blogobramje.nl/posts/Roundcube_sending_mail_broken_with_PHP_5.6_-_STARTTLS_failed/

1
jmikii

私はdovecotを使用しているので、私のソリューションはcaを/etc/dovecot/dovecot.confに追加することでした。

ssl_ca = </etc/ssl/ca.pem
0
Klaus