Apache配置文件httpd.conf/htaccess中deny和allow的使用
看下下面的apache的一个配置,具体代码如下:
Allow和Deny哟关于apache的conf文件或者htaccess文件中(配合Directory,Location,Files等),用来控制目录和文件的访问授权。
注意 deny和allow之间有一个逗号,不是空格,且只能有一个逗号,大小写不限。
所以,最常用的是:
Order Deny,Allow
Allow from All
1|0规律:
当看到apache的配置时可以从一下角度来理解,一默认,二顺序,三重叠。
- 一默认
Order allow,deny
,这句话的作用是配置allow和deny的顺序,默认只有最后一个关键字起作用,所以这里起作用的就是deny——拒绝,所以要拒绝/允许某个特殊的IP就将此策略(拒绝/允许)放在order
这一句的最后 - 二顺序
Order
规定了规则的执行(判断)顺序,不管下面的allow和deny的顺序如何,都会按着Order ....
这一句的规定的allow和deny的顺序来执行 allow和deny的规则,比如Order allow,deny
,那么限制性allow的规则,在执行deny的规则,即时下面先写的deny规则
后写的allow规则
。 - 三重叠 apache会按照order顺序,把所有规则都判断了,就像路由的规则一样,比如上面的
Allow from all
允许所有请求通过,deny from 192.9.200.69
拒绝来自192.9.200.69的包,最终结果是拒绝来自192.9.200.69的包。
2|0例子
也许上边没有说明白,我们再来看下面的例子,每个配置后面都有简单的说明,配置文件中的“#”号后边的数字表示配置项起作用的先后顺序。
1. 只允许192.9.200.69请求访问目录
- 允许所有请求访问目录
- 拒绝所有请求访问目录
- 除了192.9.200.69的请求外,其他请求都可以访问目录
Allow和Deny可以用于apache的conf文件或者.htaccess文件中(配合Directory, Location, Files等),用来控制目录和文件的访问授权。
按照上面的解释,下面的设定是无条件禁止访问:
如果要禁止部分内容的访问,其他的全部开放:
apache会按照order决定最后使用哪一条规则,比如上面的第二种方式,虽然第二句allow允许了访问,但由于在order中allow不是最后规则,因此还需要看有没有deny规则,于是到了第三句,符合ip1和ip2的访问就被禁止了。注意,order决定的“最后”规则非常重要,下面是两个错误的例子和改正方式:
错误:想禁止来自domain.org的访问,但是deny不是最后规则,apache在处理到第二句allow的时候就已经匹配成功,根本就不会去看第三句。
解决方法:Order Allow,Deny,后面两句不动,即可。
错误:想只允许来自ip1的访问,但是,虽然第二句中设定了allow规则,由于order中deny在后,所以会以第三句deny为准,而第三句的范围中又明显包含了ip1(all include ip1),所以所有的访问都被禁止了。
__EOF__

本文链接:https://www.cnblogs.com/forforever/p/13234745.html
关于博主:喜欢读书、旅行、爬山。评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】