Rewrite Handler

RewriteHandler匹配一个基于该请求的规则集合,然后根据匹配规则的变更请求。

最常见的要求是改写URI。但不限于:规则可以被配置为重定向响应、设置cookie或响应码响应、变化header。等等。

高速開始

标准Jetty公布中包括jetty-rewrite模块JAR,在lib/jetty-rewrite-*.jar,和一个样例配置文件,在etc/jetty-rewrite.xml。

为了激活重写模块,用样例配置文件。用例如以下命令启动Jetty:

$ java -jar start.jar OPTIONS=default,rewrite etc/jetty.xml etc/jetty-rewrite.xml 

注意:假设你正在使用样例test webapp执行标准Jetty公布。有一个重写模块的demo在http://localhost:8080/rewrite/

配置Rules

rules通过使用jetty.xml配置。

以下的样例文件展示怎么为server添加重写handler:

<Configure id="Server" class="org.eclipse.jetty.server.Server">
<!-- create and configure the rewrite handler -->
<New id="Rewrite" class="org.eclipse.jetty.rewrite.handler.RewriteHandler">
<Set name="rewriteRequestURI">true</Set>
<Set name="rewritePathInfo">false</Set>
<Set name="originalPathAttribute">requestedPath</Set> <!-- redirect the response. This is a redirect which is visible to the browser.
After the redirect, the browser address bar will show /redirected -->
<Call name="addRule">
<Arg>
<New class="org.eclipse.jetty.rewrite.handler.RedirectPatternRule">
<Set name="pattern">/redirect/*</Set>
<Set name="replacement">/redirected</Set>
</New>
</Arg>
</Call> <!-- rewrite the request URI. This is an internal rewrite, visible to server,
but the browser will still show /some/old/context -->
<Call name="addRule">
<Arg>
<New class="org.eclipse.jetty.rewrite.handler.RewritePatternRule">
<Set name="pattern">/some/old/context</Set>
<Set name="replacement">/some/new/context</Set>
</New>
</Arg>
</Call> <!-- reverse the order of the path sections. Internal rewrite -->
<Call name="addRule">
<Arg>
<New class="org.eclipse.jetty.rewrite.handler.RewriteRegexRule">
<Set name="regex">/reverse/([^/]*)/(.*)</Set>
<Set name="replacement">/reverse/$2/$1</Set>
</New>
</Arg>
</Call>
</New> <!-- add the rewrite handler to the server -->
<Set name="handler"><Ref id="Rewrite" /></Set>
</Configure>

很多其它的配置样例请看etc/jetty-rewrite.xml。

嵌入的样例

以下是嵌入Jetty的一个样例,和上面的配置文件做相同的事情:

Server server = new Server();

RewriteHandler rewrite = new RewriteHandler();
rewrite.setRewriteRequestURI(true);
rewrite.setRewritePathInfo(false);
rewrite.originalPathAttribute("requestedPath"); RedirectPatternRule redirect = new RedirectPatternRule();
redirect.setPattern("/redirect/*");
redirect.setReplacement("/redirected");
rewrite.addRule(redirect); RewritePatternRule oldToNew = new RewritePatternRule();
oldToNew.setPattern("/some/old/context");
oldToNew.setReplacement("/some/new/context");
rewrite.addRule(oldToNew); RewriteRegexRule reverse = new RewriteRegexRule();
reverse.setRegex("/reverse/([^/]*)/(.*)");
reverse.setReplacement("/reverse/$2/$1");
rewrite.addRule(reverse); server.setHandler(rewrite);

Rules

有几种不同类型的rules。

PatternRule

用servlet模式语法匹配请求的URI。

CookiePatternRule

添加一个cookie到响应。

HeaderPatternRule

添加/改动响应中的header。

RedirectPatternRule

重定向响应。

ResponsePatternRule

发送响应码(status或者error)。

RewritePatternRule

重写URI。

RegexRule

用正則表達式匹配请求URI。

RedirectRegexRule

重定向响应。

RewriteRegexRule

重写URI

HeaderRule

匹配请求headers。

匹配或者在一个header名称+特定的值,或者在一个header的存在(加不论什么值)。

ForwardedSchemaHeaderRule

设置请求的计划(scheme)(默认是https)。

其他

其他较为古怪的规则。

MsieSslRule

对IE5和IE6禁用为SSL保持活跃。

LegacyRule

实现RewriteHandler的遗留API。

RuleContainer

将rules组织在一起。

VirtualHostRuleContainer

包括的rules仅应用到一个特定的虚拟主机或者一套虚拟主机。

写自己定义的handlers

handler是处理请求的Jetty组件。

一些Jetty用户从不须要写Jetty handler,而是使用Servlet API(http://download.eclipse.org/jetty/stable-9/xref/org/eclipse/jetty/servlet/package-summary.html)。你能重用已经存在的Jetty
handlers,为上下文、安全、sessions和servlets,不须要不论什么扩展。然而,一些用户可能有特殊的需求或者操心足迹问题而禁用完整的servlet API。为他们实现一个Jetty handler是一种直截了当的方法,用最小的修改提供动态web内容。

Handler API

Handler接口提供了Jetty内容产生和处理的核心。实现这个接口的类被用于协调请求、过滤请求和产生内容。

Handler接口的核心API是:

public void handle(String target, Request baseRequest, HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException

这种方法的实现能处理一个请求、传递请求到还有一个handler(或servlet)、或者它能改动和/或包装请求,然后传递它。存在三种类型的handler:

 1)协调Handlers:传递请求到其他handlers(HandlerCollection、ContextHandlerCollection);

 2)过滤Handlers:放大一个请求,然后传递它到其他handlers(HandlerWrapper, ContextHandler, SessionHandler);

 3)产生Handlers:产生内容(ResourceHandler和ServletHandler)。

目标

一个handler的目标是处理请求的资源的标识符。这一般是来自一个HTTP请求的URI。然而,在以下两种环境下目标能够不同于请求的URI:

 1)假设请求被分发到一个命令的资源。比如一个命名的servlet。目标是那个资源的名称。

 2)假设请求是通过请求调度程序。目标是包括的资源的URI。不同于真正请求的URI。

请求和响应

处理方法的签名中使用的请求和响应对象是Servlet Request和Servlet Response。这些是标准的API。

更常常的是,进入这些类的Jetty实现被要求:RequestResponse

然而,因为请求和响应能够被handlers、filters和servlets包装,直接地传递实现是不可能的。以下的方法用于获取不论什么包装器下的核心实现对象:

Request base_request = request instanceof Request ? (Request)request : HttpConnection.getCurrentConnection().getRequest();
Response base_response = response instanceof Response ? (Response)response : HttpConnection.getCurrentConnection().getResponse();

注意假设handler传递请求到还有一个handler。他应该用request/response对象传递,不使用基础对象。这是为了保留被上游handlers做的封装。

分发

分发參数展示了调用处理的状态,能够为:

 1)REQUEST == 1:从一个连接器收到的原始请求;

 2)FORWARD == 2:被一个RequestDispatcher前转的请求;

 3)INCLUDE == 4:被一个RequestDispatcher包含的请求;

 4)ERROR == 8:被容器前转到一个error handler的请求。

这些对大部分的servlet和相关的handlers都是有意思的。比如,安全handler仅对REQUEST分发应用认证和授权。

处理请求

一个Handler能够处理一个请求通过:

 1)产生一个响应;

 2)过滤请求和/或响应;

 3)传递请求和响应到还有一个Handler。

以下详细讲述。

产生一个响应

OneHandler展示了怎么产生一个响应。

你能用通常的servlet响应API。通常将设置一些状态、内容headers、然后输出内容:

response.setContentType("text/html");
response.setStatus(HttpServletResponse.SC_OK);
response.getWriter().println("<h1>Hello OneHandler</h1>");

handler须要标注它完毕了对请求的处理,请求不应该被传递到其他handlers了:

Request base_request = (request instanceof Request) ? (Request)request:HttpConnection.getCurrentConnection().getRequest();
base_request.setHandled(true);

过滤请求和/或响应

一旦基础请求或响应对象被获取。你就能改动它。

一般你将做改动以完毕:

 1)拆分URI到contextPath、servletPath和pathInfo组件;

 2)为静态内容将请求和资源相关联;

 3)将请求和session相关联;

 4)将请求和安全主体相关联;

 5)在请求分发到还有一个资源期间改变URI和路径。

你也能更新请求的上下文:

 1)设置当前线程上下文类载入器;

 2)设置线程局部变量来表示当前ServletContext。

通常Jetty传递一个已改动的请求到还有一个handler。并在finally块仅仅可以还原改动:

try
{
base_request.setSession(a_session);
next_handler.handle(target,request,response,dispatch);
}
finally
{
base_request.setSession(old_session);
}

实现HandlerWrapper类的类是典型的这样的类型的handler过滤器。

传递请求和响应到还有一个Handler

一个Handler能够简单的视察请求,然后使用目标、请求URI或其他信息以选择还有一个Handler作为下一个处理请求的Handler。这些handlers通常实现HandlerContainer接口。

样例包含:

Class Handler Collection

HandlerList

ContextHandlerCollection

很多其它Handlers的信息

Jetty Latest Source XRefJetty Latest JavaDoc获取每个Jetty Handler的具体信息。

很多其它Jetty资料请看Jetty概观

版权声明:本文博客原创文章,博客,未经同意,不得转载。

Jetty:开发指导Handlers的更多相关文章

  1. Jetty开发指导:框架

    Spring设置 你能嵌入Jetty到你的项目中,也能够使用差点儿全部的IoC类型框架,包含Spring.假设全部你想做的是在你的Spring中设置Jetty Server,那么以下的xml片段能够作 ...

  2. Jetty开发指导:HTTP Client

    介绍 Jetty HTTP client模块提供易用的API.工具类和一个高性能.异步的实现来运行HTTP和HTTPS请求. Jetty HTTP client模块要求Java版本号1.7或者更高,J ...

  3. Jetty开发指导:Jetty Websocket API

    Jetty WebSocket API使用 Jetty提供了功能更强的WebSocket API,使用一个公共的核心API供WebSockets的服务端和client使用. 他是一个基于WebSock ...

  4. Jetty开发指导:WebSocket介绍

    WebSocket是一个新的基于HTTP的双向通讯的协议. 它是基于低级别的框架协议.使用UTF-8 TEXT或者BINARY格式传递信息. 在WebSocket中的单个信息能够是不论什么长度(然而底 ...

  5. Jetty使用教程(四:21-22)—Jetty开发指南

    二十一.嵌入式开发 21.1 Jetty嵌入式开发HelloWorld 本章节将提供一些教程,通过Jetty API快速开发嵌入式代码 21.1.1 下载Jetty的jar包 Jetty目前已经把所有 ...

  6. Jetty 开发指南:Jetty 内嵌开发

    Jetty的口号是“不要在Jetty中部署你的应用程序,在你的应用程序中部署Jetty!” 这意味着,作为将应用程序捆绑为要部署在Jetty中的标准WAR的替代方案,Jetty旨在成为一个软件组件,可 ...

  7. IntelliJ IDEA: maven & jetty 开发 java web

    之前使用eclipse + maven + jetty开发java web应用,本着no zuo no gain的想法, 折腾了一下Intellj idea下开发环境的搭建,顺带学习了maven re ...

  8. eclipse集成jetty开发web项目(不采用maven方式)

    以前开发过程部署项目都是采用tomcat,偶然发现jetty,所以试了下,挺方便的,直切主题. 1.下载jetty,楼主使用的jetty8,地址http://download.eclipse.org/ ...

  9. Jetty 开发指南: 嵌入式开发之HelloWorld

    Jetty 嵌入式之 HelloWorld 本节提供一个教程,演示如何快速开发针对Jetty API的嵌入式代码. 1. 下载 Jar 包 Jetty被分解为许多jar和依赖项,通过选择最小的jar集 ...

随机推荐

  1. Android 高仿 频道管理----网易、今日头条、腾讯视频 (可以拖动的GridView)附源码DEMO

    距离上次发布(android高仿系列)今日头条 --新闻阅读器 (二) 相关的内容已经半个月了,最近利用空闲时间,把今日头条客户端完善了下.完善的功能一个一个全部实现后,就放整个源码.开发的进度就是按 ...

  2. JSP的学习(1)——基本知识与底层原理

    通过之前的学习,我们已经对Servlet有所了解,现在我们先来学习JSP,当能使用JSP进行友好的页面显示之后,再回去学习Servlet的其他高级特性会将整个学习很好的融入进来. JSP,即Java ...

  3. Qt Style Sheets Examples(QT真是有很全的文档)

    http://doc.qt.io/qt-5/stylesheet-examples.html http://doc.qt.io/qt-4.8/stylesheet.html

  4. Boost Thread学习笔记五

    多线程编程中还有一个重要的概念:Thread Local Store(TLS,线程局部存储),在boost中,TLS也被称作TSS,Thread Specific Storage.boost::thr ...

  5. hadoop学习之ZooKeeper

    1. 什么是ZooKeeper? ZooKeeper是一组工具,用来配置和支持分布式调度. 它能处理分布式应用的“部分失败”问题. 什么是部分失败? 部分失败是分布式处理系统的固有特征,即发送者无法知 ...

  6. CAS 单点登录

    首先,何谓单点登录. 单点登录(Single Sign On),简称为 SSO,是眼下比較流行的企业业务整合的解决方式之中的一个. SSO的定义是在多个应用系统中,用户仅仅须要登录一次就能够訪问全部相 ...

  7. VC/MFC 工具栏上动态添加组合框等控件的方法

    引言 工具条作为大多数标准的Windows应用程序的一个重要组成部分,使其成为促进人机界面友好的一个重要工具.通过工具条极大方便了用户对程序的操作,但是在由Microsoft Visual C++开发 ...

  8. 自适应滤波器(Adaptive Filter)

    ======= Wikipedia的解释 ======= 自适应滤波器是能够根据输入信号自动调整性能进行数字信号处理的数字滤波器.作为对比,非自适应滤波器有静态的滤波器系数,这些静态系数一起组成传递函 ...

  9. 【老鸟学算法】包含 min函数的栈设计——java实现

    要求: 1. 定义栈的数据结构,要求添加一个 min函数,能够得到栈的最小元素. 2. 要求函数 min.push 以及 pop 的时间复杂度都是 O(1). 这是考验“栈”数据结构设计.众所周知,栈 ...

  10. 读一读Scktsrvr.exe的源程序

    读一读Scktsrvr.exe的源程序 使用DELPHI做多层开发的朋友们都应该对Scktsrvr.exe这个程序不陌生的,Borland公司在DELPHI中给出了它的源代码.这是一个900来行的程序 ...