【发布时间】:2023-03-15 18:12:01
【问题描述】:
我们的网站上有一个目录,我们只希望几个 IP 地址可以访问该目录。所以我们有这个 .htaccess 文件来尝试让它工作:
RewriteEngine on
RewriteCond %(REMOTE_ADDR) !^123\.123\.123\.123
RewriteCond %(REMOTE_ADDR) !^124\.124\.124\.124
RewriteCond %{REMOTE_ADDR} !^125\.125\.125\.125
RewriteCond %{REMOTE_ADDR} !^126\.126\.126\.126
RewriteCond %{REMOTE_ADDR} !^127\.127\.127\.127
RewriteCond %{REMOTE_ADDR} !^128\.128\.128\.128
RewriteCond %{HTTP_REFERER} !^http://www\.example\.com/ [NC]
RewriteCond %{HTTP_REFERER} !^http://example\.com/ [NC]
RewriteRule ^.*$ http://www.example.com [R=301,L]
我们希望它做的是,如果请求不是来自我们的 IP 地址之一(显然在上面的代码中更改了它们只是为了示例),或者引荐来源网址不是来自特定站点,然后重定向他们在别处。
出于某种奇怪的原因,它适用于位于126.126.126.126 位置的IP,但不适用于其他IP。真的无法弄清楚为什么它会因IP而有所不同。可能出了什么问题?
我知道这会带来安全问题,因为引荐来源网址可能会被欺骗,但我们很快会提出更好的解决方案,这只是临时措施。
【问题讨论】:
-
你用的是同一个浏览器吗?您没有在浏览器地址栏中输入站点 URL 吗? (那么引用者将为空)
-
我尝试了新的浏览器以确保它不是缓存问题。它应该可以直接在新的浏览器窗口中输入 URL。它适用于其中一个 IP 地址。仅当没有 IP 匹配时才需要引荐来源网址。因此,如果它们是(不是来自 IP1,也不是来自 IP2,也不是来自 IP3 ......并且推荐人不是来自 x 站点,那么摆脱它们)。
标签: redirect mod-rewrite ip block whitelist