5

我使用此代码和组件创建了多条路线:

Component component = new Component();
component.getServers().add(Protocol.HTTP, port);
component.getDefaultHost().attach(pair.uriPattern, pair.restlet);
component.getDefaultHost().attach("/heartbeat", new HeartbeatRestlet());

我的心跳代码有效。

但是当我像上面那样使用路由器时pair.restlet,它不起作用:

Router router = new Router();
Restlet fooHandler = new FooRouter();
Restlet barHandler = new BarRouter();

router.attach("/foo/{fooId}", fooHandler);
router.attach("/bar/{barId1}/{barId2}", barHandler);

Restlet 文档仅给出了使用带有Application类的路由器的示例:

public class FirstStepsApplication extends Application {

    @Override
    public synchronized Restlet createInboundRoot() {
        Router router = new Router(getContext());
        router.attach("/hello", HelloWorldResource.class);
        return router;
    }
}

实际上,使用我的基于路由器的代码与点击不存在的 URL 具有相同的效果。

所以我问:

  1. 基于路由器的方法应该实现的目标与基于组件的方法之间有什么区别吗?
  2. 我可以让这个代码使用基于路由器的方法工作吗?到目前为止,我唯一的解决方案是废弃多个路由器并附加多个组件,这需要处理更多遗留代码。
4

1 回答 1

1

我看不出在虚拟主机附件上使用路由器有什么问题,因为 Restlet 允许复合元素来构建请求处理链。

这里的问题是路由器可以支持多个路由,并且您使用精确匹配模式(实际上是默认模式)。

让我们来个样本。如果pair.uriPattern包含/test并且您在此路由上连接了路由器。/test无论您在路由器上指定什么,都只会处理路径(空路由除外;-)

我猜你想实现子路由匹配,所以你应该考虑在将路由器附加到虚拟主机时使用匹配开始:

Router router = (...)

Component component = new Component();
component.getServers().add(Protocol.HTTP, port);
component.getDefaultHost()
             .attach(pair.uriPattern, router)
             .setMatchingMode(Template.MODE_STARTS_WITH);
component.getDefaultHost().attach("/heartbeat", new HeartbeatRestlet());

在这种情况下,所有以 的值开头的请求都pair.uriPattern将由路由器处理。所以路由器应该这样定义:

Router router = new Router();
router.attach("/something", yourRestlet1);
router.attach("/somethingelse", yourRestlet2);

在这种情况下,我们将有以下行为:

  • 路线pair.uriPattern + "/something"将被处理yourRestlet1
  • 路线pair.uriPattern + "/somethingelse"将被处理yourRestlet2

事实上,这种方法是组织应用程序代码的好方法。

希望它可以帮助你,蒂埃里

于 2015-06-15T08:34:00.517 回答