web-dev-qa-db-ja.com

Roundcubeは件名なしで電子メールを送信します

最近、postfixdovecotで構成されるメールサーバーをセットアップしました。昨日、nginxroundcubeをミックスに追加しました。 SPF、DKIM、DMARC、rDNSレコードはすべて実行されます。 Gmailは私のメールを有効なものとして扱い、受信トレイに配信します。すべてが機能しています。 1つの少し厄介なことを除いて。

Androidの組み込みMUAまたは他のMUAを使用しても、すべて問題ありません。 roundcubeを使用してメールを送信したいときに問題が発生します。メールは引き続き検証され、正しく配信されますが、件名はありません。どういうわけか、roundcubeは件名フィールドを失い、件名なしで私の電子メールを送信しています。

私は7時間続けて答えを探していましたが、この問題を経験しているのは私だけのようです。これにより、サーバーや構成などに問題があると思いますが、すべての構成を4回チェックしましたが、それでもわかりません。

どんな助けでも非常に役に立ちます。よろしくお願いします。

私のメールサーバーは、CentOS 7Minimalを実行している768MBのRAMを搭載したOpenVZボックス上にあります。 Postfixバージョン:2.10.1 Dovecotバージョン:2.2.10 Roundcubeバージョン:1.1.0

僕の postconf -n出力:

alias_database = hash:/etc/aliases
alias_maps = hash:/etc/aliases
command_directory = /usr/sbin
config_directory = /etc/postfix
daemon_directory = /usr/libexec/postfix
data_directory = /var/lib/postfix
debug_peer_level = 2
debugger_command = PATH=/bin:/usr/bin:/usr/local/bin:/usr/X11R6/bin ddd $daemon_directory/$process_name $process_id & sleep 5
disable_vrfy_command = yes
html_directory = no
inet_interfaces = all
inet_protocols = all
mail_owner = postfix
mailq_path = /usr/bin/mailq.postfix
manpage_directory = /usr/share/man
mydestination = localhost
myhostname = mail.example.com
newaliases_path = /usr/bin/newaliases.postfix
non_smtpd_milters = unix:/var/run/opendkim/opendkim.sock
queue_directory = /var/spool/postfix
readme_directory = /usr/share/doc/postfix-2.10.1/README_FILES
sample_directory = /usr/share/doc/postfix-2.10.1/samples
sendmail_path = /usr/sbin/sendmail.postfix
setgid_group = postdrop
smtpd_data_restrictions = reject_unauth_pipelining
smtpd_delay_reject = no
smtpd_helo_required = yes
smtpd_helo_restrictions = reject_unknown_helo_hostname, reject_non_fqdn_helo_hostname, reject_invalid_helo_hostname
smtpd_milters = unix:/var/run/opendkim/opendkim.sock
smtpd_recipient_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination
smtpd_relay_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination
smtpd_sasl_auth_enable = yes
smtpd_sasl_path = private/auth
smtpd_sasl_type = dovecot
smtpd_sender_restrictions = reject_unknown_sender_domain
smtpd_tls_auth_only = yes
smtpd_tls_cert_file = /etc/pki/dovecot/certs/dovecot.pem
smtpd_tls_key_file = /etc/pki/dovecot/private/dovecot.pem
smtpd_use_tls = yes
strict_rfc821_envelopes = yes
unknown_local_recipient_reject_code = 550
virtual_alias_maps = mysql:/etc/postfix/mysql-virtual-alias-maps.cf
virtual_mailbox_domains = mysql:/etc/postfix/mysql-virtual-mailbox-domains.cf
virtual_mailbox_maps = mysql:/etc/postfix/mysql-virtual-mailbox-maps.cf
virtual_transport = lmtp:unix:private/dovecot-lmtp

私のRoundcube構成の抜粋はconfig/config.inc.php

$config['debug_level'] = 5;
$config['db_dsnw'] = 'mysql://user:pass@localhost/database';
$config['default_Host'] = 'tls://localhost';
$config['default_port'] = 993;
$config['smtp_server'] = 'tls://localhost';
$config['smtp_port'] = 587;
$config['ip_check'] = true;
$config['identities_level'] = 3;
$config['des_key'] = 'some key';
$config['mime_types'] = '/usr/share/nginx/html/roundcube/mime.types';
$config['preview_pane'] = true;
5
Bugra Koc

私は自分の質問に対する解決策を見つけました。

以下は、program/Steps/mail /sendmail.incの507〜513行目です。

// encoding subject header with mb_encode provides better results with asian characters
if (function_exists('mb_encode_mimeheader')) {
    mb_internal_encoding($message_charset);
    $headers['Subject'] = mb_encode_mimeheader($headers['Subject'],
        $message_charset, 'Q', "\r\n", 8);
    mb_internal_encoding(RCUBE_CHARSET);
}

これは、$headers['Subject']変数について言及している2つの場所のうちの1つです。もう1つは、変数を設定する196行目です。

私もクライアントもアジアのキャラクターとは何の関係もないので、このコードブロックをコメントアウトして何が起こるか見てみることにしました。被験者は働き始めました。 roundcubeには奇妙なバグがあるようです。これがいつか誰かに役立つことを願っています。

1
Bugra Koc