如何在 Apache 中阻止特定的用户代理

jdh*_*deb 5 apache apache2.4

我正在配置我的 Django 应用程序以通过电子邮件向我发送错误(例外)。

通常没问题 - 但我的电子邮件托管在 Office 365 上,似乎 Microsoft 正在自动扫描和加载电子邮件中的 URL。

结果是它点击了我的 Django 应用程序中的 URL,并导致另一个错误......和另一封电子邮件。最终结果:一个迷人的小邮件循环,它在几秒钟内向我发送了 50 多条消息。

我在我的 apache 日志中发现了这样的条目:

157.55.39.163 - - [22/Aug/2018:17:30:05 +0000] "GET /testerror HTTP/1.1" 500 5808 "-" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/534+ (KHTML, like Gecko) BingPreview/1.0b"
Run Code Online (Sandbox Code Playgroud)

我想阻止访问用户代理(包含“BingPreview”),所以我可以防止这个循环。

我把它放到我的虚拟主机中:

SetEnvIf User-Agent "^.*BingPreview.*$" bad_user

<Directory /path/top/my/app/>
   <Files wsgi.py>
       Require not env bad_user
   </Files>
</Directory>
Run Code Online (Sandbox Code Playgroud)

但是当我重新加载 apache 时,出现错误negative Require directive has no effect in <RequireAny> directive

jdh*_*deb 11

明白了。感谢您的提示,@Tobias K.

我启用了 mod_rewrite 因为它尚未启用。

a2enmod rewrite
Run Code Online (Sandbox Code Playgroud)

然后我将其放入我的虚拟主机中:

RewriteEngine on
RewriteCond %{HTTP_USER_AGENT}  ^.*BingPreview.*$
RewriteRule . - [R=403,L]
Run Code Online (Sandbox Code Playgroud)

并重启apache生效:

service apache2 restart
Run Code Online (Sandbox Code Playgroud)

我可以在 apache 日志中看到 BingPreview 被阻止(注意 403):

157.55.39.163 - - [22/Aug/2018:18:12:09 +0000] "GET /testerror HTTP/1.1" 403 4385 "-" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/534+ (KHTML, like Gecko) BingPreview/1.0b"


MrW*_*ite 6

但是当我重新加载 apache 时,出现错误negative Require directive has no effect in <RequireAny> directive

<RequireAny>如果没有明确说明,则为默认的“隐含”容器。

您可以通过执行类似以下操作来解决此问题:

SetEnvIf User-Agent "BingPreview" bad_user

<Directory /path/top/my/app/>
   <Files wsgi.py>
       <RequireAll>
       Require all granted
       Require not env bad_user
       </RequireAll>
   </Files>
</Directory>
Run Code Online (Sandbox Code Playgroud)

“正则表达式”BingReview与 相同^.*BingPreview.*$