AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 812137
Accepted
Calimo
Calimo
Asked: 2016-10-31 01:37:38 +0800 CST2016-10-31 01:37:38 +0800 CST 2016-10-31 01:37:38 +0800 CST

Postfix 在用户未知别名 (`"|exit 67"`) 上退回而不是拒绝邮件

  • 772

我有一个小型后缀服务器,用于我自己的几个域(与 mydestination = pcre:/etc/postfix/mydestinations 匹配)。我设置了一些非虚拟别名

alias_maps = hash:/etc/aliases
alias_database = hash:/etc/aliases

在这个文件中,我定义了通用别名

generic: someuser

有了一个recipient_delimiter = -我现在可以[email protected]用作一次性电子邮件地址。由于其中一些通用地址被垃圾邮件发送,我可以根据别名丢弃所有电子邮件:

generic-spammed: /dev/null

这很好用,但这意味着我会继续接受这些电子邮件。相反,我想拒绝他们。阅读别名文档,似乎我应该能够执行以下操作来拒绝带有“用户未知”错误的电子邮件:

generic-spammed:    |"exit 67"

不幸的是,电子邮件被退回而不是被拒绝,从而导致反向散射。这意味着它们最初被接受,并250 OK在被退回之前返回给发件人。

这类似于这个问题,除了我使用的是本地目的地,而不是虚拟目的地。我有smtpd_reject_unlisted_recipient默认设置,我怀疑我的问题是由于文档中的以下句子:

The recipient domain matches $mydestination, $inet_interfaces or $proxy_interfaces, but the recipient is not listed in $local_recipient_maps, and $local_recipient_maps is not null. 

收信人是否被列出的问题?有没有办法拒绝这些电子邮件而不是退回它们?

postconf -n返回以下内容:

alias_database = hash:/etc/aliases
alias_maps = hash:/etc/aliases
append_dot_mydomain = no
biff = no
config_directory = /etc/postfix
home_mailbox = Maildir/
inet_interfaces = all
mailbox_size_limit = 0
milter_default_action = accept
milter_protocol = 2
mua_client_restrictions = permit_sasl_authenticated, reject
mua_helo_restrictions = permit
mua_sender_restrictions = permit
mydestination = pcre:/etc/postfix/mydestinations
mydomain = xavasite.net
myhostname = dent.xavasite.net
mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128 185.26.124.183 [2001:4b98:dc2:47:216:3eff:fe3f:43d3]
myorigin = /etc/mailname
non_smtpd_milters = local:/var/run/opendkim/opendkim.sock
policy-spf_time_limit = 3600s
readme_directory = no
recipient_delimiter = -
relayhost =
smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache
smtpd_banner = $myhostname ESMTP $mail_name (Debian/GNU)
smtpd_junk_command_limit = 1
smtpd_milters = local:/var/run/opendkim/opendkim.sock
smtpd_recipient_restrictions = reject_unknown_sender_domain, reject_unknown_recipient_domain, reject_unauth_pipelining, permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination, check_policy_service unix:private/policy-spf, reject_rbl_client bl.spamcop.net, reject_rbl_client psbl.surriel.com, reject_rbl_client cbl.abuseat.org, reject_rbl_client zen.spamhaus.org,
smtpd_relay_restrictions = permit_mynetworks permit_sasl_authenticated defer_unauth_destination
smtpd_sasl_auth_enable = yes
smtpd_sasl_authenticated_header = yes
smtpd_sasl_local_domain = $myhostname
smtpd_sasl_path = private/dovecot-auth
smtpd_sasl_security_options = noanonymous
smtpd_sasl_type = dovecot
smtpd_sender_restrictions = reject_unknown_sender_domain
smtpd_tls_CAfile = /etc/ssl/2015/GandiStandardSSLCA2.pem
smtpd_tls_cert_file = /etc/ssl/2015/xavier.robin.name.crt
smtpd_tls_key_file = /etc/ssl/2015/xavier.robin.name.key
smtpd_tls_mandatory_ciphers = high
smtpd_tls_mandatory_exclude_ciphers = RC4
smtpd_tls_mandatory_protocols = !SSLv2, !SSLv3
smtpd_tls_protocols = !SSLv2, !SSLv3
smtpd_tls_session_cache_database = btree:${data_directory}/smtpd_scache
smtpd_use_tls = yes
postfix email-bounces aliases
  • 2 2 个回答
  • 288 Views

2 个回答

  • Voted
  1. Arul Selvan
    2016-10-31T09:31:21+08:002016-10-31T09:31:21+08:00

    我认为您在别名文件上的引用不正确

    generic-spammed:    |"exit 67"
    

    它应该是

    generic-spammed:    "|exit 67"
    

    此外,默认情况下,后缀将不允许传递到“|command”,因此您还需要包含以下内容

    allow_mail_to_commands = alias,forward,include
    

    http://www.postfix.org/postconf.5.html#allow_mail_to_commands

    • 1
  2. Best Answer
    Calimo
    2017-02-17T07:56:55+08:002017-02-17T07:56:55+08:00

    我找到了一种解决方法,可以使用配置拒绝这些电子邮件check_recipient_access。它允许创建一个包含针对特定电子邮件地址的 REJECT 语句的哈希数据库文件。

    我创建了一个名为/etc/postfix/alias_disable以下内​​容的文件:

    [email protected]     REJECT
    

    然后我跑并在范围内postmap alias_disable添加了一行:main.cfsmtpd_recipient_restrictions

    smtpd_recipient_restrictions =
            [...]
           **check_recipient_access hash:/etc/postfix/alias_disable**
    

    现在电子邮件被拒绝,没有退回:

    554 5.7.1 <[email protected]>: Recipient address rejected: Access denied;
    

    显然应该可以自定义拒绝消息,包括几个后缀操作,但我还没有尝试过。

    • 0

相关问题

  • Postfix 在特定端口上接受邮件

  • 让 Postfix 以两种方式处理垃圾邮件

  • Postfix 或 exim:自动/程序化和转发电子邮件设置

  • 后缀电子邮件地址

  • 什么是最好的开源电子邮件解决方案包

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve