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

apache url rewrite实现url重写配置详解

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

配置步骤:

第一步:找到apache的配置文件httpd.conf(文件在conf目录下)

第二步:你首先必须得让服务器支持mod_rewrite,如果你使用的是虚拟主机,请事先询问你的主机提供商。

打开httpd.conf,找到如下代码,把#去掉。

  1. #LoadModule rewrite_module modules/mod_rewrite.so 

找到AllowOverride None 改成 AllowOverride All,

注:AllowOverride 的参数设置为ALL,表示整台服务器上都支持URL规则重写。Apache 服务器要读每个网站下目录下的 .htaccess 文件。如果没有这个文件,或者这个文档没有定义任何关于URL重写的规则就不会有任何效果。

对于不同的网址,需要在APACHE中增加如下内容:

  1. RewriteEngine On 
  2. RewriteMap lowercase int:tolower 
  3. RewriteCond ${lowercase:%{SERVER_NAME}} ^[a-z0-9]+.eact.com.cn$ 
  4. RewriteRule ^(.+) ${lowercase:%{SERVER_NAME}}$1 [C] 
  5. ##RewriteRule ^u.eact.com.cn/(.*) /ux/index.html [L] 
  6. RewriteRule ^([a-z0-9]+).eact.com.cn/(.*) /$1/$2 [L] 

实例301跳转

例一.下面是在一个虚拟主机里定义的规则。功能是把client请求的主机前缀不是www.phpfensi.com和70.40.213.183都跳转到主机前缀为http://www.phpfensi.com,避免相同内容的网页有多个指向的域名,如http://phpfensi.com。

  1. NameVirtualHost 70.40.213.183:80  
  2. ServerAdmin php@phpfensi.com  
  3. DocumentRoot “/web”  
  4. ServerName phpfensi.com 
  5. RewriteEngine on #打开rewirte功能  
  6. RewriteCond %{HTTP_HOST} !^www.phpfensi.com [NC] #声明Client请求的主机中前缀不是www.phpfensi.com,其中 [NC] 的意思是忽略大小写  
  7. RewriteCond %{HTTP_HOST} !^70.40.213.183 [NC] #声明Client请求的主机中前缀不是70.40.213.183,其中 [NC] 的意思是忽略大小写  
  8. RewriteCond %{HTTP_HOST} !^$ #声明Client请求的主机中前缀不为空  
  9. RewriteRule ^(.*) http://www.phpfensi.com/ [L] #含义是如果Client请求的主机中的 
前缀符合上述条件,则直接进行跳转到http://www.phpfensi.com/,[L]意味着立即停止重写操作,并不再应用其他重写规则。这里的.*是指匹配所有URL中不包含换行字符,()括号的功能是把所有的字符做一个标记,以便于后面的应用.就是引用前面里的 (.*)字符。

例二.将输入 en.phpfensi.com 的域名时跳转到www.phpfensi.com

  1. RewriteEngine on  
  2. RewriteCond %{HTTP_HOST} ^en.phpfensi.com [NC]  
  3. RewriteRule ^(.*) http://www.phpfensi.com/ [L] 

实现 伪静态在每个虚拟主机的地方设置Rewrite参数

  1. <VirtualHost *:80> 
  2. ServerAdmin wweidong@sina.com 
  3. DocumentRoot "I:/Job/Java" 
  4. ServerName localhost 
  5. RewriteEngine on 
  6. RewriteRule /([0-9]+).html /test.jsp?id=$1 [PT] 
  7. RewriteRule /([0-9]+)_([0-9]+).html /content.jsp?id=$1&id2=$2 [PT] 
  8. </VirtualHost> 

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