Apache Camel的數據轉換

openkk 12年前發布 | 35K 次閱讀 Apache Camel

在做系統集成的時候,必不可少的任務就是將數據從一種格式轉換為另一種格式,再把轉換后的格式發到目標系統:

Apache Camel的數據轉換

Camel提供的Message translator可以分為:

■ Using a Processor
■ Using beans
■ Using

1,利用processor的方式在Apache Camel框架入門示例 已經有個介紹.blog.csdn.net/kkdelta/article/details/7231640

通過實現Processor的方法process(Exchange exchange),通常要做的步驟是,從inbound消息里得到數據,轉換,再放到outbound的消息里.

XXX data = exchange.getIn().getBody(XXX.class);

//轉換

exchange.getOut().setBody(yyyObject);

2,利用bean的方式,寫一個java bean如下:

public class OrderToCsvBean {
    public String map(String custom) {
        String id = custom.substring(0, 9);
        String customerId = custom.substring(10, 19);
        String date = custom.substring(20, 29);
        String items = custom.substring(30);
        String[] itemIds = items.split("@");

    StringBuilder csv = new StringBuilder();
    csv.append(id.trim());
    csv.append(",").append(date.trim());
    csv.append(",").append(customerId.trim());
    for (String item : itemIds) {
        csv.append(",").append(item.trim());
    }
    return csv.toString();
}

}</pre>

在route里的代碼如下:

from("file:d:/temp/inbox1/?delay=30000").bean(new OrderToCsvBean()).to("file:d:/temp/outbox1");

Camel有一套算法來選擇調用bean里的什么方法(比如說message的header里是否通過CamelBeanMethodName設置 了方法名稱,bean是否只有一個方法,某一個方法是否加了@Handler注解等等),這里的bean只有一個map方法,Camel會調用這個方法.

3,用route中已經定義好的transform方法,一般用的較少.

from("direct:start").transform(body().regexReplaceAll("\n", "
")).to("mock:result");

4,Camel集成對許多常用的數據格式的解析:通過調用unmarshal方法可以得到解析后的結果.

CSV:

from("file:d:/temp/inbox1/?delay=30000").unmarshal().csv().process(processor).to("file:d:/temp/outbox1");

processor里可以直接得到解析后的數據:

public class CSVProcessor implements Processor {
    @Override
    public void process(Exchange exchange) throws Exception {
        System.out.println("process...");
        List csvData = (List) exchange.getIn().getBody();
        StringBuffer strbf = new StringBuffer();
        if (csvData.get(0).getClass().equals(String.class)) {//single line CSV
strbf.append(parseOrder(csvData)); } else {//multiple line CSV for (List csvOrder : (List>) csvData) { strbf.append(parseOrder(csvOrder)); } } exchange.getOut().setBody(strbf.toString()); }

private String  parseOrder(List csvData) {        
    System.out.println(csvData.get(0) + "--" + csvData.get(1)+"--" +csvData.get(2));
    return csvData.get(0) + "--" + csvData.get(1)+"--" +csvData.get(2);
}

} </pre></LIST

 本文由用戶 openkk 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!