用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

Apache在httpd.conf配置文件中设置伪静态Rewrite

时间:2015-01-23  来源:西部数据  作者:西部数据

Apache伪静态配置方法有两种一种是直接在.htaccess使用它需要apache支持,而另一种是直接在httpd.conf中使用性能高于前者.

.htaccess文件应该被用在内容提供者需要针对特定目录改变服务器的配置而又没有root权限的情况下。如果服务器管理员不愿意频繁修改配置,则可 以允许用户通过.htaccess文件自己修改配置,尤其是ISP在同一个机器上运行了多个用户站点,而又希望用户可以自己改变配置的情况下。

虽然如此,一般都应该尽可能地避免使用.htaccess文件。任何希望放在.htaccess文件中的配置,都可以放在主配置文件的段中,而且更高效。

避免使用.htaccess文件有两个主要原因。

首先是性能。如果AllowOverride启用了.htaccess文件,则Apache需要在每个目录中查找.htaccess文件,因此,无论是否真正用到,启用.htaccess都会导致性能的下降。另外,对每一个请求,都需要读取一次.htaccess文件。

还有,Apache必须在所有上级的目录中查找.htaccess文件,以使所有有效的指令都起作用,所以,如果请求/www/htdocs/example中的页面,Apache必须查找以下文件:

  1. /.htaccess 
  2. /www/.htaccess 
  3. /www/htdocs/.htaccess 
  4. /www/htdocs/example/.htaccess 

总共要访问4个额外的文件,即使这些文件都不存在。(注意,这可能仅仅由于允许根目录”/”使用.htaccess ,虽然这种情况并不多。)

其次是安全。这样会允许用户自己修改服务器的配置,这可能会导致某些意想不到的修改,所以请认真考虑是否应当给予用户这样的特权。但是,如果给予用户较少 的特权而不能满足其需要,则会带来额外的技术支持请求,所以,必须明确地告诉用户已经给予他们的权限,说明AllowOverride设置的值,并引导他 们参阅相应的说明,以免日后生出许多麻烦。

注意,在/www/htdocs/example目录下的.htaccess文件中放置指令,与在主配置文件中段中放置相同指令,是完全等效的。

由上我们可以知道,使用.htaccess文件具有性能上的不利之处,所以我们应该尽可能避免使用.htaccess文件,下面介绍一种不使用.htaccess文件进行伪静态的方法:

Apache 1.x 的用户请检查 conf/httpd.conf 中是否存在如下两段代码:

LoadModule rewrite_module libexec/mod_rewrite.so

AddModule mod_rewrite.c

Apache 2.x 的用户请检查 conf/httpd.conf 中是否存在如下一段代码:

LoadModule rewrite_module     modules/mod_rewrite.so

如果存在,且以#开头,请删除#。然后在配置文件(通常就是 conf/httpd.conf或者conf/extra/httpd-vhosts.conf)中加入如下代码。此时请务必注意,如果网站使用通过虚拟主机来定义,请务必加到虚拟主机配置,即 中去,如果加在虚拟主机配置外部将可能无法使用。改好后然后将 Apache 重启。

实例:

①.在apache%C5%E4%D6%C3/" target="_blank">apache配置文件httpd.conf中找到:

LoadModule rewrite_module modules/mod_rewrite.so

这句,去掉前边的注释符号“#”,如果没有则添加这句.

②.在代码:

Options FollowSymLinks

AllowOverride None

下面添加伪静态代码,以Wordpress伪静态为例,代码如下:

  1. RewriteEngine On 
  2. RewriteBase / 
  3. RewriteRule ^index.php$ - [L] 
  4. RewriteCond %{REQUEST_FILENAME} !-f 
  5. RewriteCond %{REQUEST_FILENAME} !-d 
  6. RewriteRule . /index.php [L] 
  7. //开源代码phpfensi.com 

其中/usr/local/apache/htdocs/wwwtest即为要进行伪静态的网站的根目录.

③.重启apache

来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门