摘自互联网 已被后查
1. DTD约束
<!DOCTYPE urlrewrite
PUBLIC "-//tuckey.org//DTD UrlRewrite 3.0//EN"
"http://tuckey.org/res/dtds/urlrewrite3.0.dtd">
2. <urlrewrite />
2.1. default-match-type(可选):
2.1.1. regex, 默认. 所有未指定match-type属性的rule都使用java正则表达式进行匹配
2.1.2. wildcard: 所有未指定match-type属性的rule都使用通配符匹配引擎匹配
2.2. decode-using(可选):
2.2.1. header, utf8: 默认. 使用request.getCharacterEncoding()得到的编码对URL解码, 如果是空, 使用utf8.
2.2.2. null: 不进行解码. 设置为: decode-using=”null”
2.2.3. header: 仅仅使用request.getCharacterEncoding()解码
2.2.4. [encoding]: 仅仅使用一个指定的字符编码比如ISO-8859-1.
2.2.5. header, [encoding]: 对一个URL解码时使用request.getCharacterEncoding(), 如果得到的值为空, 则使用encoding指定的编码.
2.3. use-query-string(可选):
2.3.1. false: 默认. 在from进行匹配的时候, 查询字符串不会参加
2.3.2. true: 查询字符串参与from的匹配
2.4. use-context(可选):
2.4.1. false: 默认. from元素匹配时, application的contex路径将不会增加到url中
2.4.2. true: application的contex路径参与from元素的匹配
3. <rule />: 0个或多个
3.1. enabled(可选):
3.1.1. true: 默认.允许这个规则
3.1.2. false: 废弃这个规则
3.2. match-type(可选):
3.2.1. regex: 默认. 使用java正则匹配
3.2.2. wildcard: 使用通配符表达式引擎
4. <outbound-ruld />: 0个或多个. 和普通的rule非常相似, 但是这里是在response.encodeURL()方法调用时进行重写的.
4.1. enabled(可选):
4.1.1. true: 默认. 允许规则
4.1.2. false: 废弃规则
4.2. encodefirst(可选):
4.2.1. fasle: 默认, 在运行了encodeURL()方法之后运用这个重写规则
4.2.2. true: 在encodeURL()之前运用这个重写规则
5. <name />: 一个用于记录规则名称的可选元素, 可以在<rule />和<outbound-rule />上使用
6. <note />: 用于记录规则描述的一个简单可选元素, 可以用在<rule />和<outbound-rule />上.
7. <condition />: 针对规则的选择条件. 注意, 在规则运用的时候必须满足所有的条件.
7.1. type(可选):
7.1.1. header: 默认. 如果设置, 头名称必须通过<condition />的name属性指定
7.1.2. method: 请求方法. GET, POST, HEAD等
7.1.3. port: application运行的端口
7.1.4. time: 服务器当前时间(使用Unix时间戳), 这个通常被用于确保内容仅在设置的时间存活
7.1.5. year: 服务器的当前年
7.1.6. month: 服务器的当前月份
7.1.7. dayofmonth: 当天是一月的第几天, 每月第一天是1
7.1.8. dayofweek: 当天是一周的第几天, 星期天是7
7.1.9. ampm: 上午或下午
7.1.10. hourofday: 一天的第多少小时(24小时制)
7.1.11. minute: 当前服务器时间的分
7.1.12. second: 当前服务器时间的秒
7.1.13. millisecond: 当前服务器时间的毫秒
7.1.14. attribute: 检查request的属性(getAttribute)值, 要检查的属性名称通过<condition />的name指定
7.1.15. auth-type: 检查request属性的值. request.getAuthType
7.1.16. character-encoding: 接收到请求的编码
7.1.17. content-length: 请求的长度(对于拒绝响应大请求很有用)
7.1.18. content-type: 请求类型
7.1.19. context-path: 请求的contex路径
7.1.20. cookie: 检查cookie值, cookie的名称通过<condition />的name属性指定
7.1.21. parameter: 检查请求参数, 参数名称通过<condition />的name属性指定
7.1.22. path-info: 相当于request.getPathInfo()
7.1.23. path-translated: 相当于request.getTranslated()
7.1.24. protocol: 用于过滤协议
7.1.25. query-string: 得到url后面的参数字符串
7.1.26. remote-addr: IP地址过滤
7.1.27. remote-host: 远程主机过滤(注意, 仅仅在应用服务器配置了查看(远程)主机名时才可用)
7.1.28. remote-user: 当前登录用户, 如果用户被授权可用
7.1.29. requested-session-id: 当前session的id
7.1.30. request-uri: 请求URL的从协议名到查询字符串部分
7.1.31. request-url: 重构后的URL, 返回的URL包含协议, 服务器名称, 端口, 路径, 但不包含查询字符串
7.1.32. session-attribute: 检查session中的属性(getAttribute), 属性名称通过<condition />的name属性设置.
7.1.33. session-isnew: 检查session是不是新的
7.1.34. server-name: 请求发送到的服务器的主机名(从host这个头中得到的不是机器名)
7.1.35. scheme: 请求的scheme
7.1.36. user-in-role: 注意, 这里的值不能是正则表达式
7.2. name: 配合一些特殊type使用的, 可以是任何值
7.3. next:
7.3.1. and: 默认. 下一个和这一个条件都必须匹配
7.3.2. or: 下一个或这一个条件匹配
7.4. operator:
7.4.1. equal: 默认. 指定正则和真实值匹配
7.4.2. notequal: 真实值和正则不匹配
7.4.3. greater: 大于, 仅用于数值
7.4.4. less: 小于
7.4.5. greaterorequal: 大于等于
7.4.6. lessorequal: 小于等于
8. <from />: 通常在<rule />和<outbound-rule />中都必须指定一个, 值可以是正则表达式(Perl5方式的正则), 注意: from指定的url是和contex相关的
8.1. casesensitive:
8.1.1. false: 默认. 大小写不敏感
8.1.2. true: 大小写敏感
9. <to />: 可以是一个perl5样式的正则替换表达式
9.1. type:
9.1.1. forward: 默认. 请求匹配这个<rule />的所有<condition />, 并且URL使用内部跳转到”to”指定的地址(注意, 这里forward到的URL必须和UrlRewriteFilter位于同一个容器中)
9.1.2. passthrough: 和forward相同
9.1.3. redirect: 请求匹配所有<condition />和这个<rule />的<from />, 通知客户端跳转到<to />指定地址
9.1.4. permanent-redirect: 相当于做了以下事情
response.setStatus(
HttpServletResponse.SC_MOVED_PERMANENTLY
);
response.setHeader(“Location”, [<to />指定的值]);
9.1.5. temporary-redirect: 相当于做了以下事情
response.setStatus(
HttpServletResponse. SC_MOVED_TEMPORARILY
);
response.setHeader(“Location”, [<to />指定的值]);
9.1.6. pre-include
9.1.7. post-include
9.1.8. proxy: 请求URL将会以全路径被代理, 使用此特性需要引入commons-http和commons-codec包
9.2. last:
9.2.1. false: 默认. 其余<rule />将会处理如果这个匹配
9.2.2. true: 如果匹配这个规则将不会处理
9.3. encode:
9.3.1. false: <rule />下是默认值. 在rewrite之前, 用response.encodeURL([to的值])编码URL
9.3.2. true: <outbound-rule />下默认值. 不会编码URL
9.4. context:
如果应用服务器配置了允许”穿透context”通信, 那么这个属性可以被用于forward(并且仅仅能用于forward)请求到另外一个serlvet context…..也就是跨应用forward
在Tomcat上, server.xml或context.xml中配置crossContext=”true”, 例如: 允许两个应用”app”和”forum”之间通信, 那么可以如下配置:
<Context docBase=”app” path=”/app” reloadable=”true” crossContext=”true” />
<Context docBase=”forum” path=”/forum” reloadable=”true” crossContext=”true” />
10. <to />的其他方面
10.1. <to />可以是null, 意义为: 如果匹配请求不再继续, 相当于没有调用chain.doFilter
10.2. 使用$N获取<from />中配置的子组, N必须是1至10之间的数
10.3. 任何<condition />中可以使用的type中的值都可以在<to />中使用, 比如<to>/%{parameter:page}</to>
10.4. 函数调用: ${函数名: 参数1:参数2} 可以在<set />和<to />中使用
name
|
example
|
example returns
|
replace
|
${replace:my cat is a blue cat:cat:dog}
|
my dog is a blue dog
|
replaceFirst
|
${replace:my cat is a blue cat:cat:dog}
|
my cat is a blue dog
|
escape
|
${escape:a b c}
|
a+b+c
|
unescape
|
${unescape:a+b+c}
|
a b c
|
lower
|
${lower:Hello World}
|
hello world
|
upper
|
${upper:hello}
|
HELLO
|
trim
|
${trim: abc def }
|
abc def
|
11. <set />: 在匹配规则的时候, 允许设置一些值.
11.1. type:
11.1.1. request: 默认. 类似于request.setAttribute
11.1.2. session: session.setAttribute
11.1.3. response-header: response.setHeader
11.1.4. cookie: 值以”[value][:domain[:lifetime[:path]]]”的格式设置. 是指给客户端浏览器设置cookie, cookie名称由<set />的name属性指定
11.1.4.1. value: cookie的值
11.1.4.2. domain: 服务器
11.1.4.3. lifetime: 存货时间
11.1.4.4. path: cookie的path
11.1.5. status: response.setStatus
11.1.6. content-type: response.setContentType
11.1.7. charset: response.setCharacterEncoding
11.1.8. expires: 设置HTTP头中的过期时间, 设置的格式为{数值 类型}, 比如: “1 day 2 seconds”
11.1.9. locale: response.setLocale
11.1.10. parameter: 允许将request.getParameter得到的某个参数的值在这里进行重新处理
11.1.11. method: 允许将request.getMethod()得到的值进行重新处理
11.2. name: type是request, session, response-header, cookie的时候, 必须设置name
11.3. 举例:
<rule>
<condition name=”user-agent”>Mozilla/3/.0 (compatible; AvantGo .*)</condition>
<from>.*</from>
<set name=”client”>AvantGo</set>
</rule>
<rule>
<condition name=”user-agent”>UP/.Browser/3.*SC03 .*</condition>
<from>.*</from>
<set name=”client”>Samsung SCH-6100</set>
</rule>
12. <run />: 允许在<rule />和<condition />都匹配的时候, 执行一个对象方法
12.1. class: 全限定名的类名, 期望调用方法的类名.
12.2. method(可选): 默认值为run. 期望调用的方法名. 该方法必须有两个参数(HttpServletRequest request, HttpServletResponse response). 注意, 如果该对象有init(ServletConfig)或destroy()方法, 在创建和销毁对象的时候会自动调用, ServletConfig中可以得到初始化参数, 参数通过<init-param />的方式传递:
<run class=”selfimpr.MyServlet” method=”doGet”>
<init-param>
<param-name>id</param-name>
<param-value>1</param-value>
</init-param>
</run>
12.3. neweachtime: 默认false. 表明是否每次请求都创建一个对象实例.
13. Tip
13.1. 在配置中如果要使用”&”, 用&
13.2. 简单起见, 给<from />的配置前面和后面分别加上^, $, 这两个是正则表达式中的强制开始和结尾标志
13.3. 如果使用<outbound-rule>要记得代码中的url都是编码过的
13.4. 正则表达式非常复杂灵活, 请阅读java.util.regex.Pattern中的java正则介绍
13.5. 如果觉得正则难以理解, 可以使用通配符方式
13.6. contex是非常重要的, 如果有一个应用的context是”/myapp”, 并且你的请求是”/myapp/somefolder/somepage.jsp”, 容器交给UrlRewriteFilter的url会是”/somefolder/somepage.jsp”, 这可能难以理解, 但是在你的<rule>和<condition>中不要包含context path, 它是容器负责处理的.
14. 通配符:
通配符匹配引擎可以替代正则表达式, 在<condition>和<rule>中设置match-type是wildcard用以开启支持通配符.(或者设置default-match-type)
例如:
/big/url/*匹配/big/url/abc.html但是不匹配/big/url/abc/dir/或/big/url/abc/
/big/url/**匹配/big/url/abc.html, /big/url/abc/dir/和/big/url/abc/
也可以和正则的替换一样, 每个*代表一个参数, 在<set>和<to>中用$N的方式使用
相关推荐
在实际应用中,这些类可能与XML配置文件(如`urlrewrite.xml`)配合使用,定义一系列的URL重写规则。配置文件中的规则会映射到`Rule`对象,然后在`UrlRewriteFilter`中应用这些规则。 总结来说,这个Java实现的URL...
为了实现图片防盗链,根据网络上搜集的资料加上自己的实践,终于实现了iis下的图片防盗链功能。 实施步骤: 1.下载比较出名的www.helicontech.com... 另修改规则无需重启iis,只需要修改httpd.ini配置文件即可。
### 关于HAProxy的相关配置文件详解 #### 一、引言 HAProxy(High Availability Proxy)是一款免费、快速且可靠的高性能TCP/HTTP应用交付代理软件。它被广泛应用于负载均衡场景,可以有效地分发网络流量至多个...
下面是一个使用UrlRewrite模块的例子: ```xml <rewrite> <match url="^([^/]+)/(.*)\.aspx$" /> <action type="Rewrite" url="{R:1}/{R:2}.php" appendQueryString="false" /> </rewrite> ``` 这个...
- **启用父路径**:在PHP应用中,可能需要使用相对路径,需要修改PHP的配置文件php.ini,找到`allow_url_fopen = On`确保允许父路径访问。 2. **建立web文件夹** - 创建一个用于存放网站文件的文件夹,例如C:\...
3. **定义规则**:创建一个XML文件(如`urlrewrite.xml`),在其中定义URL重写规则。这些规则可以根据正则表达式匹配原始URL,并将其重写为目标URL。例如,你可以将动态参数化的URL重写为静态的、更友好的形式。 4....
- 考虑使用URL重写模块,如ISAPI_Rewrite或IIS URL Rewrite,以提高网站的SEO友好性和URL管理。 - 定期检查和安装安全补丁,以保护服务器免受潜在的安全威胁。 以上就是在IIS环境下配置PHP4的详细步骤。虽然这个...
2. **配置文件详解**:Apache的配置主要通过httpd.conf文件进行,手册将详细解释各个配置指令的作用,如ServerRoot、Listen、VirtualHost等,帮助用户定制服务器行为。 3. **模块管理**:Apache有很多可选模块,如...
运行`./configure --prefix=/usr/local/apache2 --enable-so --enable-rewrite`进行编译配置,这里指定了Apache的安装路径、支持模块动态加载以及URL重写功能。 4. **编译与安装** `make && make install`命令...
**DWR[1].xml配置文件说明书.doc**:这份文档详细解释了DWR的配置文件DWR.xml的结构和用途。DWR.xml是DWR的核心配置文件,用于定义哪些Java类和方法可以被JavaScript访问,以及其他高级设置,如安全性、缓存策略等。...
3. **配置网站属性** - 设置网站的身份验证方式,如匿名身份验证、基本身份验证等。 - 配置默认文档,如index.html,使访问网站时无需指定具体页面。 - 管理日志文件,设置记录访问信息。 4. **FTP服务器配置** ...
规则通常包含`<rule>`元素,其中`from`属性定义匹配的URL模式,`to`属性定义重写后的URL。 **进阶应用** "rewrite_intermediate_src.rar"可能包含更复杂的用例,如条件重写、正则表达式匹配和使用变量。你可以根据...
这可能涉及到URL重写规则的配置,使用IIS的URL重写模块或者第三方工具(如Mod_Rewrite for IIS)来实现。 7. **安全优化**: - 配置SSL证书以启用HTTPS,确保数据传输的安全性。 - 定期更新IIS和服务器上的所有...
- **更新 core.php 文件**:解释了如何更新核心配置文件。 - **多个CakePHP应用共用同一套核心**:介绍了如何在一个服务器上运行多个CakePHP应用,同时共用一套核心文件。 通过上述知识点的介绍,读者不仅能够全面...
ASP.NET(ASP的后续版本)中提供了UrlRewrite模块,但在纯ASP中,可能需要自定义HTTP模块或使用第三方库来实现类似功能。 7. **错误处理**:在ASP源码中,正确处理错误是非常重要的。可以通过`On Error Resume Next...
2. **URL重写**:使用IIS6.0 metabase.xml或第三方工具如URLRewrite模块,可以实现动态URL到静态URL的转换,优化SEO。 3. **FastCGI**:用于支持PHP等解释型语言,提供比ISAPI更好的性能和稳定性。 **六、IIS6.0的...
- **可选配置**:提供了关于如何进一步优化配置文件的建议。 - **关于 mod_rewrite 的注释**:强调了正确配置 Apache 的 mod_rewrite 模块对于 URL 重写的重要性。 ##### 2.2 博客教程 - **创建 Post Model**:详细...
扩展模块配置,rewrite配置? **解析:**配置Apache服务器虚拟主机涉及多个方面,包括但不限于: - 使用 `<VirtualHost>` 指令定义不同的虚拟主机。 - 通过 `mod_rewrite` 实现URL重写功能,提升SEO效果和用户友好...
这是一种ISAPI筛选器,可以运行在IIS服务器上,通过特定的配置文件httpd.ini来解析URL重写规则,从而对访问进行重定向或者拦截。 防盗链的基本思路是通过检查HTTP请求的Header信息中的Referer字段来判断访问来源。...
id=1的形式出现,不知道我说的明不明白,我昨天就这个问题给他们解释了半天...... 独立服务器设置 Win2003必备的环境装好后,打开iis 在【默认网站】上右键属性,找到【ISAPI筛选器】选项卡 ...