postfix
最近、とで構成されるメール サーバーをセットアップしましたdovecot
。昨日、nginx
とroundcube
を追加しました。SPF、DKIM、DMARC、rDNS レコードはすべて完了しています。Gmail は私のメールを有効なものとして扱い、受信トレイに配信します。すべて正常に動作しています。ただし、1 つだけ厄介な点があります。
Android の組み込み MUA または他の MUA を使用する場合は、すべて問題ありません。問題は、roundcube を使用してメールを送信しようとするときに発生します。メールは検証され、正しく配信されますが、件名がありません。どういうわけか、roundcube は件名フィールドを失い、件名なしで電子メールを送信します。
7 時間ずっと答えを探し続けていますが、どうやらこの問題を経験しているのは世界で私だけのような気がします。サーバーか設定か何かに問題があるのではないかと思うのですが、設定をすべて 4 回チェックしましたが、まだわかりません。
どのようなご助力でも大変助かります。ご協力に感謝いたします。
私のメール サーバーは、768 MB の RAM を搭載した OpenVZ ボックス上にあり、CentOS 7 Minimal を実行しています。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;
答え1
私は自分の疑問に対する解決策を見つけました。
以下は、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);
}
これは、変数について言及している 2 つの箇所のうちの 1 つです$headers['Subject']
。もう 1 つは、変数を設定する 196 行目です。
私も私のクライアントもアジア文字とは無関係なので、このコード ブロックをコメント アウトして何が起こるか確認してみることにしました。すると、なんと、Subject が機能し始めました。Roundcube には奇妙なバグがあるようです。これがいつか誰かの役に立つことを願っています。