Apache2.4和Apache2.2访问控制配置语法对比

Posted Our_sky

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Apache2.4和Apache2.2访问控制配置语法对比相关的知识,希望对你有一定的参考价值。

一、访问控制

在Apache2.2版本中,访问控制是基于客户端的主机名、IP地址以及客户端请求中的其他特征,使用Order(排序), Allow(允许), Deny(拒绝),Satisfy(满足)指令来实现。

在Apache2.4版本中,使用mod_authz_host这个新的模块,来实现访问控制,其他授权检查也以同样的方式来完成。旧的访问控制语句应当被新的授权认证机制所取代,即便Apache已经提供了mod_access_compat这一新模块来兼容旧语句。

这里有一些实例,用新方法取代旧语句实现相同的访问控制

实例1:所有请求都被拒绝

Apache2.2 配置:

代码如下:

Order deny,allow #排序,先拒绝后允许
Deny from all #拒绝所有

Apache2.4 配置:

 

代码如下:

Require all denied #拒绝所有
 

实例2:所有请求都被允许

 

Apache2.2 配置:

 

代码如下:

Order allow,deny #排序,先允许后拒绝
Allow from all #允许所有

 

Apache2.4 配置:

 

代码如下:

Require all granted #拒绝所有

 

实例3:example.org所有请求都被允许,其他拒绝

Apache2.2 配置:

代码如下:

Order Deny,Allow #排序,先拒绝后允许
Deny from all #拒绝所有
Allow from example.org #允许example.org

 

Apache2.4 配置:

代码如下:

Require host example.org #拒绝所有

 

二、Apache Require 指令

了解更多require指令用法:《Apache Module mod_authz_core》

附:常见访问控制指令

 

代码如下:

Require all granted #允许所有
Require all denied #拒绝所有
Require env env-var [env-var] ... #允许,匹配环境变量中任意一个
Require method http-method [http-method] ... #允许,特定的HTTP方法
Require expr expression #允许,表达式为true
Require user userid [ userid ] ... #允许,特定用户
Require group group-name [group-name] ... #允许,特定用户组
Require valid-user # #允许,有效用户
Require ip 10 172.20 192.168.2 #允许 特定IP

以上是关于Apache2.4和Apache2.2访问控制配置语法对比的主要内容,如果未能解决你的问题,请参考以下文章

Apache2.4使用require指令进行访问控制

Apache2.4使用require指令进行访问控制–允许或限制IP访问/通过User-Agent禁止不友好网络爬虫

Apache2.2和Apache2.4中httpd.conf配置文件 权限的异同

Apache2.4.x与Apache2.2.x的一些区别

apache2.2 和 2.4 虚拟主机配置文件

Apache2.4.6 添加虚拟主机