`
woshixushigang
  • 浏览: 576282 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类

URLRewriteFilte

 
阅读更多
1)URLRewriteFilter简介: 
是一个用于改写 URL 的 Web 过滤器,典型应用就把动态 URL 静态化,网站
改版新旧URL替换(方便搜索引擎爬取)……… 
2) URLRewriteFilter配置参数详解: 
一)web.xml 中过滤器配置:   
1)下载urlrewritefilter.jar 包, 并加入到WEB-INF/lib下 
2)  在 WEB-INF/web.xml 中增加过滤器: 
  <filter> 
    <filter-name>UrlRewriteFilter</filter-name> 
    <filter-class>org.tuckey.web.filters.urlrewrite.UrlRewriteFilter</filter-class> 
</filter> 
<filter-mapping> 
   <filter-name>UrlRewriteFilter</filter-name> 
   <url-pattern>/*</url-pattern>//<!--  拦截所有的 url --> 
</filter-mapping> 
3)web.xml中可配置的过滤器初始化参数: 
1.) confReloadCheckInterval:  
配置文件重加载间隔. 0表示随时加载, -1表示不重加载,  默认-1 
     2) confPath: 
        配置文件路径. 是相对context的路径, 默认/WEB-INF/urlrewrite.xml 
     3) logLevel: 
    设置日志级别, 可以是: TRACE, DEBUG, INFO(默认), WARN, ERROR, FATAL,   
     log4j,commons,slf4j,sysout:{level}(比如  sysout:DEBUG), 如果你使用普通的日志级 
别有一定困难, 可以调为: sysout:DEBUG(表明是使用控制台输出的调试级别) 
4) statusPath 
设置改变状态路径, 不能和已经安装的应用冲突(注意,  默认是/rewrite-status),  注意, 
必须以/开始 
5) statusEnabled:  
设置status是否开启, 期望得到的值是 true, false, 默认true 
6. statusEnabledOnHosts:  
设置允许status的主机, *可以被用作通配符, 默认是”localhost, local, 127.0.0.1” 
7. modRewriteConf:  
设置 rewrite 模式,  默认是 false,  使用 mod-rewrite(可以参照 apache 服务器的
mod_rewrite相关资料)方式的配置文件,  如果设置为 true并且 confPath没有设置则配置
文件路径将会被默认为/WEB-INF/.htaccess 
8. modRewriteConfText:  
从这些参数的值加从载 mod_rewrite 样式的配置, 设置这些参数则其他所有的参数
都会被忽略. 比如: 
<init-param> 
<param-name>modRewriteConfText</param-name> 
<param-value> 
RewriteRule ^/~([^/]+)/?(.*) /u/$1/$2 [R] 
RewriteRule ^/([uge])/([^/]+)$ /$1/$2/ [R] 
</param-value></init-param> 9. allowConfSwapViaHttp:  
设 置是 否 允许 通过 HTTP 方 式 交互 设 置 参数 ,  比如 ,  通 过 调用
/rewrite-status/?conf=WEB-INF/urlrewrite2.xml 
 二) URLrewrite.xml 配置: 
   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.10. 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. <set />: 在匹配规则的时候, 允许设置一些值. 
   10.1. type: 
   10.1.1. request: 默认. 类似于 request.setAttribute 
   10.1.2. session: session.setAttribute 
   10.1.3. response-header: response.setHeader 
   10.1.4.  cookie: 值以”[value][:domain[:lifetime[:path]]]”的格式设置.  是指给客户
端浏览器设置cookie, cookie名称由<set />的name属性指定 
   10.1.4.1. value: cookie的值 
   10.1.4.2. domain: 服务器 
   10.1.4.3. lifetime:  存货时间 
   10.1.4.4. path: cookie的path 
   10.1.5. status: response.setStatus 
   10.1.6. content-type: response.setContentType 
   10.1.7. charset: response.setCharacterEncoding 
   10.1.8. expires:  设置HTTP 头中的过期时间,  设置的格式为{数值 类型}, 比如: “1 
day 2 seconds” 
   10.1.9. locale: response.setLocale 
   10.1.10.  parameter: 允许将 request.getParameter 得到的某个参数的值在这里进行重
新处理 
   10.1.10. method: 允许将request.getMethod()得到的值进行重新处理 
   10.2. name: type是request, session, response-header, cookie的时候, 必须设置name 
   
10.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> 
11. <run />: 允许在<rule />和<condition />都匹配的时候,  执行一个对象方法 
   11.1. class: 全限定名的类名,  期望调用方法的类名. 
   11.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> 
   11.3. neweachtime: 默认false. 表明是否每次请求都创建一个对象实例. 
12. Tip 
   12.1. 在配置中如果要使用”&”, 用&amp; 
   12.2. 简单起见,  给<from  />的配置前面和后面分别加上^,  $, 这两个是正则表达式
中的强制开始和结尾标志 
   12.3. 如果使用<outbound-rule>要记得代码中的url都是编码过的 
   12.4. 正则表达式非常复杂灵活, 请阅读java.util.regex.Pattern中的java正则介绍 
   12.5. 如果觉得正则难以理解,  可以使用通配符方式 
   12.6.  contex 是非常重要的,  如果有一个应用的 context 是”/myapp”,  并且你的请
求是”/myapp/somefolder/somepage.jsp”,  容器交给 UrlRewriteFilter 的 url 会是”
/somefolder/somepage.jsp”,  这可能难以理解,  但是在你的<rule>和<condition>中不要包含
context path, 它是容器负责处理的. 
13. 通配符: 
   通配符匹配引擎可以替代正则表达式,  在<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的方式使用 
14) <to />的其他方面  
14.1. <to />可以是null,  意义为:  如果匹配请求不再继续, 相当于没有调用 chain.doFilter  
14.2. 使用$N获取<from />中配置的子组, N必须是 1至 10之间的数  
14.3.  任何<condition  />中可以使用的 type 中的值都可以在<to  />中使用,  比如
<to>/%{parameter:page}</to>  
14.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 
 
 

 

 

分享到:
评论

相关推荐

    UrlRewrite实现二级域名或多级域名

    《使用UrlRewrite实现二级域名或多级域名》 在互联网应用开发中,URL重写(UrlRewrite)是一项重要的技术,它允许我们根据特定规则改变请求的URL,从而实现诸如优化SEO、隐藏真实路径、实现二级或多级域名等功能。...

    实验室管理系统 微信小程序+SSM毕业设计 源码+数据库+论文+启动教程.zip

    实验室管理系统 微信小程序+SSM毕业设计 源码+数据库+论文+启动教程 项目启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS

    基于java的苹果网吧计费管理系统设计与实现.docx

    基于java的苹果网吧计费管理系统设计与实现.docx

    纸中世界-跳跃游戏.sb3

    纸中世界-跳跃游戏.sb3

    Keysight 网络分析仪新建校准件操作指导

    本操作指导用于在 ENA 系列网络分析仪 E5080B 上自定义校准件。目前 Keysight 网络分析仪的 PNA 系列 N52xxB、P50xx 系列、P937x 系列、PXI 板卡式网分以及 ENA 系列的 E5080B、E5081B 的操作界面均统一到如下界面,操作方式相同。

    调查海域浮游动物各类群栖息密度的空间分布表格.docx

    调查海域浮游动物各类群栖息密度的空间分布表格.docx

    ssm框架Java项目源码-高校毕业生就业管理系统+jsp毕设-大作业.zip

    本项目“高校毕业生就业管理系统”是一套基于SSM框架(Spring+SpringMVC+MyBatis)精心开发的Java Web应用,旨在为高校毕业生、高校就业指导部门以及企业用户提供一个高效、便捷的就业信息管理平台。 系统主要功能包括:学生用户可以查看和发布个人简历,搜索并筛选合适的工作岗位,申请心仪的职位;企业用户可以发布招聘信息,筛选和查看应聘者的简历,进行面试邀请等操作;高校就业指导部门则可以对学生的就业情况进行统计和分析,以更好地提供就业指导服务。 此外,系统采用了B/S架构,用户只需通过浏览器即可访问,无需安装客户端软件,方便快捷。数据库设计合理,数据存储安全,系统性能稳定。 本项目的开发,不仅为计算机相关专业的学生提供了一个实践SSM框架的好机会,帮助他们更好地理解和掌握Java Web开发技术,还能有效提升高校毕业生的就业效率和质量。

    使用 Python 进行视频编辑.zip

    电影剪辑 笔记MoviePy 最近升级到 v2.0,引入了重大的重大变化。有关如何更新 v2.0 代码的更多信息,请参阅本指南。MoviePy(在线文档在此处)是一个用于视频编辑的 Python 库剪切、连接、插入标题、视频合成(又名非线性编辑)、视频处理和创建自定义效果。MoviePy 可以读取和写入所有最常见的音频和视频格式,包括 GIF,并且可以在 Windows/Mac/Linux 上运行,并搭载 Python 3.9+。例子在此示例中,我们打开一个视频文件,选择 10 到 20 秒之间的子剪辑,在屏幕中心添加标题,然后将结果写入新文件# Import everything needed to edit video clipsfrom moviepy import *# Load file example.mp4 and keep only the subclip from 00:00:10 to 00:00:20clip = VideoFileClip("long_examples/example2.mp4").with_subcl

    基于java的视频播放器系统设计与实现.docx

    基于java的视频播放器系统设计与实现.docx

    基于java的车辆出租管理系统设计与实现.docx

    基于java的车辆出租管理系统设计与实现.docx

    mqtt等协议的pcap文件

    mqtt等协议的pcap文件

    小白的Python入门教程部分章节源码.zip

    学习python

    修木工施工规范及流程.docx

    修木工施工规范及流程.docx

    适用于 Windows,Linux 和 Python 3 (3.5,3.6,3.7) 的 Tensorflow Faster R-CNN.zip

    适用于 Windows/Linux 和 Python 3 (3.5/3.6/3.7) 的 Tensorflow Faster R-CNNtf-faster-rcnn使用 Python 3 在 Windows 和 Linux 上使用 Tensorflow Faster R-CNN这是在 Windows 和 Linux 上编译 Faster R-CNN 的分支。它深受这里和这里的出色工作的启发。目前,此存储库支持 Python 3.5、3.6 和 3.7。感谢@morpheusthewhite请注意我没有时间或意图修复此分支的所有问题,因为我不将其用于商业用途。我创建此分支只是为了好玩。如果您想做出任何承诺,我们非常欢迎。Tensorflow 已经发布了一个对象检测 API。请参考它。https: //github.com/tensorflow/models/tree/master/research/object_detection如何使用此分支安装 tensorflow,最好是 GPU 版本。按照说明操作。如果没有安装 GPU 版本,则需要注释掉代码中的所有 GP

    章节2:编程基本概念之python程序的构成

    Python是一种高级、解释型、面向对象的编程语言,以其简洁的语法、强大的功能和广泛的应用领域而著称。它无需事先编译,代码在运行时逐行解释执行,提供了极大的灵活性和快速开发的能力。Python支持多种数据类型,包括整数、浮点数、字符串、布尔值、列表、元组、字典和集合等,以及丰富的操作符和流程控制结构,使得开发者可以编写出复杂且灵活的代码。 Python拥有一个广泛的标准库,涵盖了文件操作、网络通信、文本处理、正则表达式、数学运算等多个领域,为开发者提供了大量的模块和函数。此外,Python还拥有丰富的第三方库,如NumPy、Pandas、Matplotlib等用于数据分析和可视化的库,以及Django、Flask等用于Web开发的框架,这些库和框架进一步扩展了Python的应用领域和功能。 Python在Web开发、数据科学、人工智能、自动化运维和游戏开发等多个领域都有广泛的应用。在Web开发方面,Python提供了Django和Flask等强大的Web框架,使得开发者可以轻松地开发出各种Web应用和网站。在数据科学领域,Python是数据科学家的首选工具,其强大的数据处理能力和丰

    毕设源码-基于python的西西家居全屋定制系统的设计与实现_ijsj--论文-期末大作业+说明文档.rar

    本项目是基于Python语言开发的西西家居全屋定制系统,旨在为家居行业提供一个高效、智能的定制解决方案。项目涵盖了从客户需求分析、设计方案生成、材料选购到最终订单生成的全过程,力求实现家居定制的数字化和智能化。 在主要功能方面,系统具备强大的客户管理模块,能够详细记录和分析客户的定制需求。设计模块则采用先进的三维建模技术,为客户提供直观、真实的家居设计方案预览。此外,系统还整合了丰富的材料数据库,方便客户根据自身喜好和预算进行材料选择。 框架方面,项目采用了B/S架构,确保了系统的稳定性和可扩展性。后端使用Python的Django框架,前端则结合了HTML、CSS和JavaScript等技术,实现了用户界面的友好和响应速度。 开发此项目的目的,不仅是为了满足家居行业对个性化定制的需求,也为计算机相关专业的学生提供了一个实践和学习的平台,有助于提升他们的实际开发能力。

    简单连接到 Binance Public API.zip

    Binance公共API连接器Python 这是一个轻量级库,可作为Binance 公共 API的连接器支持的 API/api/*/sapi/*现货 Websocket 市场动态现货用户数据流现货 WebSocket API包含测试用例和示例可定制的基本 URL、请求超时和 HTTP 代理可以显示响应元数据安装pip install binance-connector文档https://binance-connector.readthedocs.ioRESTful API使用示例from binance.spot import Spotclient = Spot()# Get server timestampprint(client.time())# Get klines of BTCUSDT at 1m intervalprint(client.klines("BTCUSDT", "1m"))# Get last 10 klines of BNBUSDT at 1h intervalprint(client.k

    离线安装eclipse的aptana插件详细中文最新版本

    Aptana是一个非常强大,开源,JavaScript-focused的AJAX开发IDE。 Aptana的特点包括: 1JavaScript,HTML,CSS语言的Code Assist功能。 2Outliner(大纲):显示JavaScript,HTML和CSS的代码结构。

    学习自律养成小程序 微信小程序+SSM毕业设计 源码+数据库+论文+启动教程.zip

    学习自律养成小程序 微信小程序+SSM毕业设计 源码+数据库+论文+启动教程 项目启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS

    认知能力评估表.docx

    认知能力评估表.docx

Global site tag (gtag.js) - Google Analytics