我是靠谱客的博主 大力冬日,最近开发中收集的这篇文章主要介绍apache的AllowOverride以及Options使用详解,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

    通常利用Apache的rewrite模块对URL 进行重写的时候,rewrite规则会写在 .htaccess 文件里。但要使 apache能够正常的读取.htaccess 文件的内容,就必须对.htaccess 所在目录进行配置。AllowOverride参数就是指明Apache服务器是否去找.htacess文件作为配置文件,如果设置为none,那么服务器将忽略.htacess文件,如果设置为All,那么所有在.htaccess文件里有的指令都将被重写。对于AllowOverride,还可以对它指定如下一些能被重写的指令类型。

    从安全性考虑,根目录的AllowOverride属性一般都配置成不允许任何Override ,即

<Directory />
AllowOverride None
</Directory> 

    在 AllowOverride 设置为None 时, .htaccess 文件将被完全忽略。当此指令设置为 All 时,所有具有 ".htaccess" 作用域的指令都允许出现在.htaccess 文件中。而对于URL rewrite 来说,至少需要把目录设置为:

< Directory /myblogroot/>
AllowOverride FileInfo
< /Directory> 

 

    在要支持url rewirte的目录启用 Options FollowSymLinks和AllowOverride All

Alias /php "c:/web/php/"
<Directory "c:/web/php/">
Options Indexes FollowSymLinks
AllowOverride All
Order allow,deny
Allow from all
</Directory> 

    这样通过http://localhost:8080/php/访问时,/php/和其下面的子目录将支持url rewrite。

 

AllowOverride的参数:

 1. AuthConfig 允许使用与认证授权相关的指令(AuthDBMGroupFile, AuthDBMUserFile, AuthGroupFile, AuthName, AuthType, AuthUserFile, Require, 等)。

 2. FileInfo 允许使用控制文档类型的指令(DefaultType, ErrorDocument, ForceType, LanguagePriority, SetHandler, SetInputFilter, SetOutputFilter, mod_mime中的 Add* 和 Remove* 指令等等)、控制文档元数据的指令(Header, RequestHeader, SetEnvIf, SetEnvIfNoCase, BrowserMatch, CookieExpires, CookieDomain, CookieStyle, CookieTracking, CookieName)、mod_rewrite中的指令(RewriteEngine, RewriteOptions, RewriteBase, RewriteCond, RewriteRule)和mod_actions中的Action指令。

3. Indexes 允许使用控制目录索引的指令(AddDescription, AddIcon, AddIconByEncoding, AddIconByType, DefaultIcon, DirectoryIndex, FancyIndexing, HeaderName, IndexIgnore, IndexOptions, ReadmeName, 等)。

4. Limit 允许使用控制主机访问的指令(Allow, Deny, Order)。

5. Options[=Option,...] 允许使用控制指定目录功能的指令(Options和XBitHack)。可以在等号后面附加一个逗号分隔的(无空格的)Options选项列表,用来控制允许Options指令使用哪些选项

 

Options参数
1.  All         准许以下除MultiViews以外所有功能
2.  MultiViews  允许多重内容被浏览,如果你的目录下有一个叫做foo.txt的文件,那么你可以通过/foo来访问到它,这对于一个多语言内容的站点比较有用
3.  Indexes     若该目录下无index文件,则准许显示该目录下的文件以供选择
4.  IncludesNOEXEC  准许SSI,但不可使用#exec和#include功能
5.  Includes    准许SSI
6.  FollowSymLinks  在该目录中,服务器将跟踪符号链接。注意,即使服务器跟踪符号链接,它也不会改变用来匹配不同区域的路径名,如果在<Local>;标记内设置,该选项会被忽略
7.  SymLinksIfOwnerMatch  在该目录中仅仅跟踪本站点内的链接
8.  ExecCGI     在该目录下准许使用CGI

最后

以上就是大力冬日为你收集整理的apache的AllowOverride以及Options使用详解的全部内容,希望文章能够帮你解决apache的AllowOverride以及Options使用详解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(66)

评论列表共有 0 条评论

立即
投稿
返回
顶部