由于web工程要实现伪静态化或者地址迁移,就需要使用这种技术来完成地址的重定向。
当外部请求到达apache,Apache调用Apache Url Rewrite中的定义来重写由用户浏览器指定请求的URL,最后被重写的URL如果是重定向,则送交浏览器做再一次请求;如果是代理则把重写后的URL交给代理模块请求最终的内容(Content),最后把内容送回给浏览器。
现在开始配置apache使其可以进行url rewrite 。
首先、在httpd.conf 中找到 #LoadModule rewrite_module modules/mod_rewrite.so
将前面的 # 去掉。目的,使路径重写生效。
然后、在此配置文件最后面增加路径重写配置即可。
注意:
a、RewriteEngine on 是必须的。让路径重写生效。
b、 RewriteRule ^/myapp/(.*)$ /$1 [L,PT] 此句将myapp过滤掉。一般没有应用好服务器配置的话,用网址打开网站,容易看到应用名。如果你访问应用时,地址栏含有应用名,加上此句话,就可以将你的应用名去掉。即用户不可看到了。 myapp 是你的应用名哦。可别直接复制。
c、注意到 (.*) $1这些东西了吧。一个括号中的东西,是对应一个$占位的。
这句话,你就可以看到了。总共4个(),后面有四个$*,相对。位置很重要。位置指的是$1,$2,第一个、第二个位置。
d、在看[L,PT] 这个,这个是有含义的L是最后一个的规则。具体还是看专业文档。我一般就用这两个[L,PT]。我想一般这样也差不多 了。
3、apache 路径重写,是对动态路径的重写。还看最后的一个配置就可以看到了。即达到的效果是,用户访问时,地址栏中,显示的是html文档,但后台tomcat服务器,用的是jsp进行相应。至于apache+tomcat配置,可以阅读:
关于重写规则:
1) R[=code](force redirect) 强制外部重定向
强制在替代字符串加上http://thishost[:thisport]/前缀重定向到外部的URL.如果code不指定,将用缺省的302 HTTP状态码。
2) F(force URL to be forbidden)禁用URL,返回403HTTP状态码。
3) G(force URL to be gone) 强制URL为GONE,返回410HTTP状态码。
4) P(force proxy) 强制使用代理转发。
5) L(last rule) 表明当前规则是最后一条规则,停止分析以后规则的重写。
6) N(next round) 重新从第一条规则开始运行重写过程。
7) C(chained with next rule) 与下一条规则关联
如果规则匹配则正常处理,该标志无效,如果不匹配,那么下面所有关联的规则都跳过。
T=MIME-type(force MIME type) 强制MIME类型
9) NS (used only if no internal sub-request) 只用于不是内部子请求
10) NC(no case) 不区分大小写
11) QSA(query string append) 追加请求字符串
12) NE(no URI escaping of output) 不在输出转义特殊字符
例如:
13) PT(pass through to next handler) 传递给下一个处理
例如:
14) S=num(skip next rule(s)) 跳过num条规则
15) E=VAR:VAL(set environment variable) 设置环境变量