[英]Allow access in htaccess based on the HTTP:X-FORWARDED-FOR
嗨,我应该只允许特定的IP地址(HTTP:X-FORWARDED-FOR地址)访问文件。 我是通过以下方式完成的
Options +FollowSymLinks
RewriteEngine On
RewriteBase /
RewriteCond %{HTTP:X-FORWARDED-FOR} !^xxx.xxx.x.xx$
RewriteRule ^$ http://xxx.xxx.x.xx/access_denie.php [R=301,L]
现在我必须允许它为多个ip,例如yyy.yy.y.yy。 我怎么能用htaccess做到这一点
RewriteCond
的^xxx.xxx.x.xx$
部分只是一个正则表达式。 您可以轻松使用组添加更多IP地址:
^(xxx\.xxx\.x\.xx|yyy\.yy\.y\.yy)$
你会注意到我已经全部逃脱了.
用反斜杠 - 这是因为.
在正则表达式中具有特殊含义,如果您希望它只匹配文字,则需要对其进行转义.
字符。
所以你的新RewriteCond
将如下所示:
RewriteCond %{HTTP:X-FORWARDED-FOR} !^(xxx\.xxx\.x\.xx|yyy\.yy\.y\.yy)$
您可以轻松添加更多IP地址,只需将它们与|
分开即可 字符。
但请注意,这种方法并不能为您提供任何真正的安全保障。 欺骗一个请求来解决这个问题会很容易。 如果您需要安全性,则应使用SSL和适当的身份验证系统。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.