wso2 esb PayloadFactory如何支持数组

时间:2015-10-26 10:12:57

标签: scripting wso2 wso2esb esb

在ESB中,我们可以使用payloadFactory创建请求。但有效负载工厂是一种预先配置的json格式,并用值替换占位符。 如果请求包含数组,则非常困难。有什么建议吗? 有效载荷工厂样品

<payloadFactory media-type="json">
            <format>
             {
                "tableId":"$1",
                "min":"$2",
                "max":"$3"
            }
            </format>
            <args>
                <arg evaluator="xml" expression="$func:tableId"/>
                <arg evaluator="xml" expression="$func:min"/>
                <arg evaluator="xml" expression="$func:max"/>
            </args>
        </payloadFactory>

2 个答案:

答案 0 :(得分:4)

就像Rajeev已经提到的那样,可以使用脚本调解器来实现。我已经这样做了一个分页功能,从包中的db读取整个内容。

以下是我所做的一个例子,希望这也有帮助。

<script language="js">print("Start JS");
        var pageSize = 500;
        var pagesRest = mc.getProperty("result_count") % pageSize;
        var pages = ((mc.getProperty("result_count")-pagesRest)/pageSize)+1;
        var xmlResponse = mc.getPayloadXML();
        var rowCount= mc.getProperty("result_count");
        print("rowCount:  " + rowCount+"    pages:"+pages);
        var rowData = {
            rows : []
        };
        var resultCount=0;

        for(var i=1;i&lt;=pages;i++)
        {
            print("Building page "+i);
            rowData.rows[i] = {};
            rowData.rows[i].from = "" + (i-1)*pageSize ;
            rowData.rows[i].to= "" + (pageSize * i);
            rowData.rows[i].orderBy = "caseid";

            resultCount+=pageSize;
        }

        mc.setPayloadJSON(rowData);

此致 马丁

答案 1 :(得分:1)

对于更多动态/复杂的有效负载修改,您可以使用Script Mediator编写一些javascript代码来构建有效负载。