Apache rewrite重写规则的常见应用

一、为什么需要用重写规则

---- 网站的生命在于不断地进行更新和维护,根据业务发展的需求转移服务器进行维护、重新组织目录结构、变换URL甚至改变到新的域名等情况是经常发生的。为了让客户不会因此受到任何影响,最好的方法就是使用Apache Rewrite Rule(重写规则)。

二、重写规则的作用范围

---- 1.使用在Apache主配置文件httpd.conf中。

---- 2.使用在httpd.conf里定义的配置中。

---- 3.使用在基本目录的跨越配置文件.htaccess中。

三、重写规则的应用条件

---- 当用户的Web请求最终被导向到某台Web服务器的Apache守护进程,Apache根据配置文件判断该请求是主配置还是,再根据用户在浏览器中请求的URL来匹配重写规则,并且根据实际的请求路径匹配.htaccess中的重写规则,最后把请求的内容传回给用户。该响应可能有2种。

---- 1.将请求内容外部重定向(Redirect)到另一个URL

---- 让浏览器再次以新的URL发出请求(R=301或者R=302,临时的或是永久的重定向)。

---- 例如,一个网站有正规的URL和别名URL,对别名URL进行重定向到正规URL,或者网站改换成了新的域名,则把旧的域名重定向到新的域名。

---- 2.由Apache内部子请求代理产生新的内容送回给客户[P,L]

---- 这是Apache内部根据重写后的URL,通过代理模块请求内容并将最终内容送回给客户,客户端浏览器不必再次请求,浏览器中的URL不会被重写,但实际内容由Apache根据重写规则后的URL生成。

---- 例如,在公司防火墙上运行的Apache启动这种代理重写规则,代理对内部网段上的Web服务器的请求。

四、重写规则怎样工作

---- 我们假定在编译Apache时已经把mod_rewrite编译成模块,确信您的httpd.conf中有LoadModule rewrite_module libexec/mod_rewrite.so,并且在Addmodule中有Addmodule mod_rewrite.c,则可以使用重写规则。

---- 当外部请求到达Apache,Apache调用重写规则中的定义来重写由用户浏览器指定请求的URL,最后被重写的URL如果是重定向,则送交浏览器做再一次请求;如果是代理则把重写后的URL交给代理模块请求最终的内容(Content),最后把内容送回给浏览器。

五、何时使用.htaccess中的重写规则定义

---- 假如您对网站内容所在的服务器没有管理员权限,或者您的网站内容放在ISP的服务器上托管,无法改写主配置文件,但是您对Web站点内容所在的目录有写权限,则可以设置自己的.htaccess文件达到同样的目的。但您需要确定主配置文件中对您的网站所在的目录定义了下面的内容,否则您的.htaccess不会工作。

---- < Directory /usr/local/apache/htdocs/www.abc.com> options indexes followsymLinks

---- allowoverride all

---- < /Directory >

六、应用举例

---- 假定Apache被编译安装在主机192.168.1.56的/usr/local/apache目录下面,同时编译了重写和代理模块。

---- 1.隐藏Apache下的某个目录,使得对该目录的任何请求都重定向到另一个文件

---- (1)httpd.conf的实现方法

---- 我们将下面的部分放到/usr/local/apache/conf/httpd.conf中。

---- < Directory "/usr/local/apache/htdocs/manual/"> options Indexes followsymlinks

---- allowoverride all

---- rewriteengine on

---- rewritebase /

---- rewriterule ^(.*)$ index.html.en [R=301]

---- < /Directory >

---- 注: “rewriteengine on”为重写引擎开关,如果设为“off”,则任何重写规则定义将不被应用,该开关的另一用处就是如果为了临时去掉重写规则,可以将引擎开关设为“off”再重新启动Apache即可,不必将其中的各条重写规则注释掉。

---- “rewritebase /”的作用是如果在下面的rewriterule定义中被重写后的部分(此处为文件名index.html.en)前面没有“/”,则表明是相对目录,相对于这个rewritebase后面的定义也就是/usr/local/apache/htdocs/index.html.en,否则,如果此处没有“rewritebase /”这一项,则被重写成,显然是不正确的。

---- 我们也可以不用“rewritebase /”,而是将其改为如下部分。

---- rewriteengine on

---- rewriterule ^(.*)$ /index.html.en [R=301]

---- 或者更改为:

---- rewriteengine on

---- rewriterule ^(.*)$ [R=301]

---- (2).htaccess的实现方法

---- 我们将下面的部分放到httpd.conf中。

---- < Directory "/usr/local/apache/htdocs/manual/"> options Indexes followsymlinks

---- allowoverride all

---- < /Directory >

---- 然后将下面的部分放到/usr/local/apache/htdocs/manual/.htaccess中。

---- rewriteengine on

---- rewritebase /

---- rewriterule ^(.*)$ index.html.en [R=301]

---- 注: 对文件.htaccess所做的任何改动不需要重启动Apache。

---- 您还可以利用.htaccess方案将这个manual目录重定向到用户jephe自己的主目录。

---- rewriteengine on

---- rewritebase /~jephe/

---- rewriterule ^(.*)$ $1 [R=301]

---- 这样,对manual目录下任何文件的请求被重定向到~jephe目录下相同文件的请求。

---- 2.将对于username的主页请求转换为对的请求

---- 对于HTTP/1.1的请求包括一个Host: HTTP头,我们能用下面的规则集重写 .com/anypath到/home/username/anypath。

---- rewriteengine on

---- rewritecond %{HTTP_HOST} ^www.[^.]+.host.com$

---- rewriterule ^(.+) %{HTTP_HOST}$1 [C]

---- rewriterule ^www.([^.]+).host.com(.*) /home/$1$2

---- 注: “rewritecond”表明是条件重写规则,当满足后面定义的条件后才会应用下面的重写规则,“rewritecond”有各种变量,请查阅相关文档。

---- 3.防火墙上的重写规则代理内部网段上服务器的请求

---- NameVirtualhost 1.2.3.4

---- < Virtualhost 1.2.3.4:80 > servername

---- rewriteengine on

---- proxyrequest on

---- rewriterule ^/(.*)$ [P,L]

---- < /Virtualhost >

---- 注: 当外部浏览器请求时,将被解析到IP地址1.2.3.4,Apache交由mod_rewrite处理,转换成后再交由代理模块mod_proxy,得到内容后传送回用户的浏览器。

---- 4.基本预先设定的转换Map表进行重写rewritemap

---- 转换到Map表中规定的URL,前面是中的定义。

---- rewritelog /usr/local/apache/logs/rewrite.log

---- rewriteloglevel 9

---- rewriteengine on

---- proxyrequest on

---- rewritemap sitemap txt:/usr/local/apache/conf/rewrite.map

---- rewriterule ^/([^/]+)+/(.*)$ [C]

---- rewriterule (.*)::([a-z]+)$ ${sitemap:$2|http://h.i.j.k/} [R=301,L]

---- 文件/usr/local/apache/conf/rewrite.map的内容如下:

---- sg

---- sh

---- 注: 当用户请求时被重写为。当需要调试时请用rewritelog和 rewriteloglevel 9联合,9为最大,即得到最多的调试信息;最小为1,表示得到最少的调试信息;默认为0,表示没有调试信息。

---- sitemap的语法是${sitemap: LookupKey | Defaultvalue},有些书上把$写成了%是错误的。

(作者:吴阿亭)

(0)

相关推荐

  • 让Apache支持Rewrite静态页面重写的方法

    首先确定您使用的 Apache 版本,及是否加载了 mod_rewrite 模块. 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_rew

  • apache rewrite规则实现白名单

    需求: 六个文件的入口,其他都重定向到index 自己的思路: 正则找出不是六个文件的URL的模式,进行过滤. 对比同事的结果,自己思路的问题: 1. 想找出所有不符合规则的,越想越多,无法下手.----------------   思路错误,应该 制定白名单, 2. 概念错误, 弄错 REQUEST_URI 和 REQUEST_STRING 的概念   基础知识不牢固. 最后结果: 复制代码 代码如下: <IfModule mod_rewrite.c> RewriteEngine on Re

  • Apache Rewrite url重定向功能的简单配置

    1.Apache Rewrite的主要功能 就是实现URL的跳转和隐藏真实地址,基于Perl语言的正则表达式规范.平时帮助我们实现拟静态,拟目录,域名跳转,防止盗链等 2.Apache Rewrite的配置 Apache下的Rewrite配置主要有两种,一种是针对整个apache服务器的配置,此种配置的Rewrite规则是直接在httpd.conf下书写.配置步骤如下: (1)去除httpd.conf文件中"#LoadModule rewrite_module modules/mod_rewri

  • 13个实用的Apache Rewrite重写规则

    1.去掉域名中的www标记 复制代码 代码如下: RewriteCond %{HTTP_HOST} !^jb51\.net$ [NC]RewriteRule .? http://jb51.net%{REQUEST_URI} [R=301,L] 2.去掉www标记,但是保存子域名 复制代码 代码如下: RewriteCond %{HTTP_HOST} ^www\.(([a-z0-9_]+\.)?jb51\.net)$ [NC]RewriteRule .? http://%1%{REQUEST_UR

  • Apache Rewrite实现URL的301跳转和域名跳转

    如果要想用到rewrite模块,必须先安装或加载rewrite模块.方法有两种一种是编译apache的时候就直接安装rewrite模块,别一种是编译apache时以DSO模式安装apache,然后再利用源码和apxs来安装rewrite模块. 基于服务器级的(httpd.conf)有两种方法,一种是在httpd.conf的全局下直接利用RewriteEngine on来打开rewrite功能;另一种是在局部里利用RewriteEngine on来打开rewrite功能,下面将会举例说明,需要注意

  • 用ISAPI_Rewrite让IIS也支持如Apache下.htaccess的URL重写

    前些日子用Linux做服务器写了一些东西,发现Apache下的.htaccess真是个好东西!不仅能实现URL真重写,还能实现假重写.真重写可以有效降低代码量与服务器资源消耗量,伪重写可以有效减少服务器的静态文件体积,节约了空间,真是不错!其实htaccess的功能远不只如此. 言归正传,那么IIS下能不能也实现htaccess这样激动人心的功能呢?ASP.NET2.0这个东东不是服务器级的,不能胜任重写这个重任,那么只有交给ISAPI了,在网上搜索,还居然真有公司(组织)开发了这种东东!不可思

  • 学习Apache的mod rewrite、access写法

    Apache 的 mod rewrite RewriteEngine On RewriteBase /B2B/website/ RewriteRule ^article-([0-9]+)\.html$ view_details.php?browse=profile&id=$1 以上这个测试通过的.如果不行关键是服务器端,以后的怎么改就发挥了 关于图片的 可以加一个 /503(id)/title.htm 这样一定不重复了,用503或其他数字或者是abc也行,不顾oabc还想不是很理想,学学ii的,

  • apache的rewrite规则使用说明

    rewrite标志R[=code](force redirect) 强制外部重定向 强制在替代字符串加上http://thishost[:thisport]/前缀重定向到外部的URL.如果code不指定,将用缺省的302 HTTP状态码.F(force URL to be forbidden)禁用URL,返回403HTTP状态码.G(force URL to be gone) 强制URL为GONE,返回410HTTP状态码.P(force proxy) 强制使用代理转发.L(last rule)

  • apache rewrite_module模块使用教程

    把 [url]http://wwww.aaaaaaaaa.com/bbb.php?id=888[/url] 的地址形式改为 [url]http://wwww.aaaaaaaaa.com/888.htm[/url] 或者 [url]http://wwww.aaaaaaaaa.com/yourname/888.htm[/url] 当然可以按照你的要求随便变. APACHE的 MOD_rewrite模块. 大家可以看一个演示的一个 PHP学习论坛 [url]http://www.phpx.com/ha

  • 开启Apache mod_rewrite模块示例代码

    启用mod_rewrite模块 在conf目录的httpd.conf文件中找到 LoadModule rewrite_module modules/mod_rewrite.so 将这一行前面的#去掉. 2.在要支持url rewirte的目录启用 Options FollowSymLinks和AllowOverride All Alias /php "c:/web/php/" 复制代码 代码如下: <Directory "c:/web/php/"> Op

  • Apache rewrite的重写相关的参数说明

    Apache mod_rewrite规则重写的标志一览 R[=code](force redirect) 强制外部重定向 强制在替代字符串加上http://thishost[:thisport]/前缀重定向到外部的URL.如果code不指定,将用缺省的302 HTTP状态码. F(force URL to be forbidden)禁用URL,返回403HTTP状态码. G(force URL to be gone) 强制URL为GONE,返回410HTTP状态码. P(force proxy)

  • 浅谈apache和nginx的rewrite的区别

    1. Nginx Rewrite规则相关指令 Nginx Rewrite规则相关指令有if.rewrite.set.return.break等,其中rewrite是最关键的指令.一个简单的Nginx Rewrite规则语法如下: rewrite ^/b/(.*)\.html /play.php?video=$1 break; 如果加上if语句,示例如下: if (!-f $request_filename) { rewrite ^/img/(.*)$ /site/$host/images/$1

随机推荐