即时使用spring mvc(客户端)和ESB Mule流(服务器端),其中包含java组件(类)。
事情就是我在客户端获得了一个“EXPORT”按钮,当点击它时会触发ESB Mule中的SELECT * FROM表,然后在java组件中创建一个包含该信息的文件服务器端:
这是骡子流(添加通用名称)
<flow name="EXPORT_TABLE_DATA">
<ajax:servlet-inbound-endpoint channel="/export_table" responseTimeout="10000"/>
<jdbc:outbound-endpoint exchange-pattern="request-response"
queryKey="export_table_data"
queryTimeout="-1"
connector-ref="ExtendedRoutingConnector">
<jdbc:query key="export_routing_table_data"
value="SELECT * FROM table_name"/>
</jdbc:outbound-endpoint>
<component class="com.web.esb.component.GenerateRoutingTableTextFile" />
</flow>
这是在GenerateRoutingTableTextFile
Java组件内部。
File dir = new File("routing-data");
if(!dir.exists()) {
dir.mkdir();
}
BufferedWriter writer = new BufferedWriter(new FileWriter(dir +"/" + "tabledata_" + System.currentTimeMillis() + ".txt"));
ArrayList<CaseInsensitiveHashMap> arrayList;
try{
arrayList = (ArrayList) eventContext.getMessage().getPayload();
for(CaseInsensitiveHashMap map : arrayList){
writer.write("** data line from SQL Query **"));
writer.newLine();
}
writer.close();
} catch (Exception e){
writer.close();
e.printStackTrace();
}
return writer;
事实是,这是在项目中创建一个文件夹。我想做的是将文件发送到客户端,以便弹出另存为...
如何将其推送到客户端?有什么想法吗?
提前致谢。