Apache Camel框架之HTTP路由

继介绍完Camel如何处理FTP,JMS接口之后,今天介绍一下系统集成的时候经常遇到的另一个接口,HTTP,一个示例需求如下图所示:(图片来源于Camel in Action)


本文给出一个简单的代码示例如何用Camel来实现这样一个应用:

1,在一个JAVA类里配置如下路由:这里只示例了HTTP的部分,其他功能实现可以参见Apache Camel框架系列的其他博客.

public class HttpPollWithQuartzCamel {
    public static void main(String args[]) throws Exception {
        CamelContext context = new DefaultCamelContext();
        context.addRoutes(new RouteBuilder() {
            public void configure() {                
                from("quartz://report?cron=10 * * * * ?&stateful=true")
                .to("http://localhost:8080/prjWeb/test.camelreq")
                .to("file:d:/temp/outbox?fileName=http.csv");
                );
            }
        });
        context.start();
        boolean loop = true;
        while (loop) {
            Thread.sleep(25000);
        }
        context.stop();
    }
}

对上面代码的简单解释: from("quartz://report?cron=10 * * * * ?&stateful=true"),配置一个quartz Job,每隔10秒发送一个HTTP request,将收到的内容保存为文件.

这里的http url可以是任何可以访问的http url,如果在http访问时候需要代理可以这么配置:"http://www.baidu.com?proxyHost=proxy.xxx.com&proxyPort=8080"

这个例子需要用到quartz,和httpclient等jar包,可以从这里下载: http://download.csdn.net/detail/kkdelta/4051072


  • 6
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Apache Camel 是一个开源的集成框架,它提供了丰富的组件和路由模式,支持从不同的数据源和协议中获取数据,并将它们转换成目标格式,最终将其路由到目标系统。下面是一个简单的动态路由示例,你可以参考它来配置 Apache Camel。 首先,你需要添 Apache Camel 的相关依赖到你的项目中,比如 Maven 依赖: ``` <dependency> <groupId>org.apache.camel</groupId> <artifactId>camel-core</artifactId> <version>x.x.x</version> </dependency> ``` 接下来,你需要编写一个 CamelContext 的配置文件,比如 routes.xml。在这个文件中,你可以定义路由器、处理器和其他相关组件。这里是一个简单的示例: ``` <camelContext xmlns="http://camel.apache.org/schema/spring"> <route> <from uri="direct:start"/> <choice> <when> <simple>${header.type} == 'A'</simple> <to uri="direct:a"/> </when> <when> <simple>${header.type} == 'B'</simple> <to uri="direct:b"/> </when> <otherwise> <to uri="direct:c"/> </otherwise> </choice> </route> <route> <from uri="direct:a"/> <to uri="log:A"/> </route> <route> <from uri="direct:b"/> <to uri="log:B"/> </route> <route> <from uri="direct:c"/> <to uri="log:C"/> </route> </camelContext> ``` 在这个示例中,我们定义了一个路由器,它从 direct:start 开始,根据 header.type 的值动态地路由到不同的处理器中。如果 type 的值为 A,它将被路由到 direct:a;如果值为 B,它将被路由到 direct:b;否则,它将被路由到 direct:c。然后我们定义了三个处理器,它们分别输出 A、B 和 C。 最后,你需要启动你的 CamelContext。你可以在 Spring 中使用 CamelContextFactoryBean 来配置和启动你的 CamelContext,或者在 Java 中使用 CamelContext 的 API。下面是一个简单的 Java 启动示例: ``` CamelContext context = new DefaultCamelContext(); context.addRoutes(new RouteBuilder() { public void configure() { from("direct:start") .choice() .when(header("type").isEqualTo("A")).to("direct:a") .when(header("type").isEqualTo("B")).to("direct:b") .otherwise().to("direct:c"); from("direct:a").to("log:A"); from("direct:b").to("log:B"); from("direct:c").to("log:C"); } }); context.start(); ``` 这样,你就可以使用 Apache Camel 来动态路由你的消息了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值