标签 url重写 下的文章

apache重写模块学习(3)

对YYYY转变为XXXX的向前兼容

描述:
在转变了大批document.YYYY文件为document.XXXX后(比如.html→.phtml),如何保持URL的向前兼容(仍然虚拟地存在)?
解决方案:
只须按基准文件名重写,并测试带有新的扩展名的文件是否存在,如果存在则用新的,否则仍然用原来的。

将document.html重写为document.phtml的向后兼容的规则集
当且仅当document.phtml存在且document.html不存在的时候
RewriteEngine on
RewriteBase /~quux/
# 剪切并记住basename
RewriteRule ^(.*)\.html$ $1 [C,E=WasHTML:yes]
# 如果存在的话就重写为document.phtml
RewriteCond %{REQUEST_FILENAME}.phtml -f
RewriteRule ^(.*)$ $1.phtml [S=1]
# 否则返回先前的basename
RewriteCond %{ENV:WasHTML} ^yes$
RewriteRule ^(.*)$ $1.html

昨天在家里安装例子配置的死活不行,后来还是改动了下代码才实现的

RewriteEngine on
#RewriteCond %{EVN:html} !^ok$
RewriteRule ^(.*)\.html $1 [C,E=html:ok]
RewriteCond %{REQUEST_FILENAME}.phtml -f
RewriteRule (.*) $1.phtml [S=1]
#RewriteBase /mod_rewrite_test/
RewriteCond %{REQUEST_FILENAME}.html -f
RewriteRule (.*) $1.html 

今天来公司,试试,竟然是ok的。。。,贴上公司代码

RewriteEngine on
RewriteBase /
# 剪切并记住basename
RewriteRule ^(.*)\.html$ $1 [C,E=html:yes]
# 如果存在的话就重写为document.phtml
RewriteCond %{REQUEST_FILENAME}.phtml -f
RewriteRule ^(.*)$ $1.phtml [S=1]
# 否则返回先前的basename
RewriteCond %{ENV:html} ^yes$
RewriteRule ^(.*)$ $1.html

公司和家里不同的地方是,xampps,公司是用的wampserver,不知道是不是apache版本的不同。。。。或者是其他的什么原因。。。
在公司配置的时候,是成功了,但是,.phtml的文件的html标签不会被解析成html标签,会原样输出,找的的解决办法是
打到Apache主配置文件,搜索“AddType text/html .shtml”:

#AddType text/html .shtml .html .htm  
#AddOutputFilter INCLUDES .shtml .html .htm  

把这两行前面的#去掉。然后重启Apache,可以解析html文件了。
没有按照上面的做,而是另起了一行

AddType text/html .phtml

再在公司电脑上面安装了同一个版本的xampps,也是ok的。。。。。。估计是昨天哪里写的不对

新旧文件的替换
http://test.com/a.html,访问这个网址的时候,正常应该访问网站根目录下的a.html文件,但是需要一个效果,在访问上面url的时候,实际访问的是网站根目录下的b.html文件代码如下

RewriteEngine on
RewriteRule ^a\.html$ b.html 

上面这样的是可以的,并且浏览器的url也不会改变,依然是http://test.com/a.html,但是如果想要在访问的文件改变的同时,使浏览器的url也发生变化,那就需要重定向的指令
代码如下

RewriteEngine on
RewriteRule ^a\.html$ b.html [R]

可是这句代码报错了,并且浏览器的url变成了http://test.com/D:/xampps/htdocs/test/b.html
然后加上***rewrite base / *** 就是ok的了
结合http://apache.jz123.cn/rewrite/rewrite_tech.html的说明,我想,在进入目录级的htaccess文件下的处理的时候,其实url已经转换成文件实际路径了,在进行替换也是对文件路径的替换,而不是替换url,所以才会出现在重定向的时候,url里面包含的是文件的路径,加上rewrite base之后,在进入的htaccess文件的时候,路径会被转变回url,再进行替换,就是ok的了,rewrite base 还有就是会加在重写后的url前面

apache重写模块学习(2)

下面的一些操作都是在windows下进行的
1.在多个目录中搜索页面

RewriteEngine On
RewriteCond      D:/wamp/wamp/www/m.xxx.cn/c/%{REQUEST_URI} -f
RewriteRule ^(.*) /c/$1 [L]
RewriteCond      D:/wamp/wamp/www/m.xxx.cn/a/%{REQUEST_URI} -f
RewriteRule ^(.*) /a/$1 [L]
RewriteCond      D:/wamp/wamp/www/m.xxx.cn/b/%{REQUEST_URI} -f
RewriteRule ^(.*) /b/$1 [L]

URL是http://m.xxx.cn/b.html,在a目录下是b目录和网站的根目录下都是有b.html这个文件的,但是因为这样的规则,回去访问a目录下的b.html文件
RewriteCond中的%{REQUEST_URI}应该是代表的/b.html,因为%{REQUEST_URI}前面的的那个/去掉也是可以正常起作用的,前面的路径部分好像是一定要写成绝对路径,相对路径我试了下不行,或者是还不知道相对路径的写法应该是怎样写
REQUEST_URI是代表的网址部分的'/b.html'的内容
来测一测
在网站的根目录下的htaccess文件下设置

RewriteEngine On
RewriteRule ^zj http://www.baidu.com [R,L]

当url是m.xxx.cn/zj的时候会实现跳转
改写规则

RewriteRule ^\/zj http://www.baidu.com [R,L]

或者

RewriteRule ^/zj http://www.baidu.com [R,L]

再在网站根目录下的a文件夹下的htaccess文件中设置

RewriteEngine On
RewriteRule ^zj http://www.baidu.com [R,L]

当url为m.xxx.cn/a/zj才会跳转
RewriteRule的^(.*)里面的查找字符串是从当前文件夹之后的字符串,比如
url:http://www.xxxx.com/a/b/c
在网站根目下的hataccess文件的查找字符串是基于a/b/c
在网站根目下的a文件下的hataccess文件的查找字符串是基于b/c
2.虚拟用户主机
描述:
如果需要为用户username支持一个***www.username.host.domain.com***的主页,但不在此机器上建虚拟主机,而是仅用在此机器上增加一个DNS A记录的方法实现。
解决方案:
仅能对包含"Host: "头的HTTP/1.1请求实现。可以使用以下规则集内部地将***http://www.username.host.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

我自己测试的时候是
访问http://www.xxx.baidu.com/index.html实际访问的是根目录下xxx/xxx/index.html,用这个上面的代码不行,会造成死循环,不知道是不是因为环境不一样的原因,我就自己改了下

RewriteEngine On
RewriteCond   %{HTTP_HOST}          ^www\.([a-zA-Z_]*)\.baidu\.com$
RewriteCond   %{REQUEST_FILENAME}   !-f
RewriteRule   ^(.*)                 %{HTTP_HOST}$1          [C]
RewriteRule   ^www\.([^.]+)\.baidu\.com\/?(.*) $1/$1/$2 

加了一句判断,就不会进入死循环了,但是如果访问的文件里面的那个文件不存在的话,还是会进入死循环,例如现在的url是http://www.xxx.baidu.com/index.html,按照上面的规则的话就会去访问根目录下a/index.html,如果文件正常存在的话,可以正常访问,但是如果文件是不存在的,就会进入死循环,不知道有没有更好的方法,使文件不存在的时候不是显示死循环的信息(403)而是进入404页面????

http://apache.jz123.cn/rewrite/index.html