2016-09-26 77 views
2

我想使用xagent原理使用Apache Poi从Notes视图创建导出。如何用“xagent”创建多个导出?

但是,而不是1导出的文件与多个工作表我想创建多个导出,每个只包含1张工作表。

可能吗?例如

importPackage(java.lang); 
importPackage(org.apache.poi.hssf.usermodel); 

var fieldList = sessionScope.fList; 

var sheetName = "viewData"; 
var workbookName = "WBViewData"; 

var vName = sessionScope.viewName; 
var nc: NotesView = database.getView(vName); 
var doc: NotesDocument; 
var ndoc: NotesDocument; 

doc = nc.getFirstDocument(); 

for (d = 1; d <= nc.getEntryCount(); d++) { 

    //Create a new workbook object from the poi library 
    var wb: HSSFWorkbook = new HSSFWorkbook(); 
    //Create additional sheets using same syntax and different sheet name 
    var sheet1: HSSFSheet = wb.createSheet(sheetName); 

    //Create helper class and styles for dates 
    var createHelper: HSSFCreationHelper = wb.getCreationHelper(); 
    var dateStyle: HSSFCellStyle = wb.createCellStyle(); 
    dateStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy")); 

    var headerStyle: HSSFCellStyle = wb.createCellStyle(); 
    var headerFont: HSSFFont = wb.createFont(); 
    headerFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); 
    headerStyle.setFont(headerFont); 

    //Create the Column Header Rows 
    var row: HSSFRow = sheet1.createRow(0); 
    for (i = 0; i <= fieldList.length - 1; i++) { 

     var hCell: HSSFCell = row.createCell((java.lang.Integer)(i)); 
     hCell.setCellValue(fieldList[i]); 
     hCell.setCellStyle(headerStyle); 
    } 

    var row: HSSFRow = sheet1.createRow(d); 

    // process document... 


    //Create the filename for the spreadsheet  
    var fileName = workbookName + ".xls"; 


    // The Faces Context global object provides access to the servlet environment via the external content 
    var extCont = facesContext.getExternalContext(); 
    // The servlet's response object provides control to the response object 
    var pageResponse = extCont.getResponse(); 
    //Get the output stream to stream binary data 
    var pageOutput = pageResponse.getOutputStream(); 

    // Set the content type and headers 
    pageResponse.setContentType("application/x-ms-excel"); 
    pageResponse.setHeader("Cache-Control", "no-cache"); 
    pageResponse.setHeader("Content-Disposition", "inline; filename=" + fileName); 
    //Write the output, flush the buffer and close the stream 
    wb.write(pageOutput); 
    pageOutput.flush(); 
    pageOutput.close(); 


    ndoc = nc.getNextDocument(doc); 
    doc.recycle(); 
    doc = ndoc; 
} 

// Terminate the request processing lifecycle. 
facesContext.responseComplete(); 
+1

您认为这应该如何运作?一个HTTP请求应该用多个响应来应答,每个响应包含一个文件?不,这不会使用HTTP。或者一个HTTP请求应该回答一个包含多个文件的响应?这可以使用HTTP。只需发送响应主体中所有文件的字节。但操作系统如何分离文件?使用包含工作簿文件的ZIP存档(一个文件)将是唯一的选择。 –

+0

@AxelRichter我知道这听起来不是逻辑,但如果你碰巧知道解决方法。当然,我可以在后端创建文档,并将它们存储在Notes文档中... –

回答

3

这个问题不是关于XPages或POI,而是对web互动如何工作的基本理解。每个发送给任何服务器的请求都只有一个Stream来返回数据。该流可以使用附件头重定向到文件。它仍然是一个流。 所以如果你想在一个流中有多个文件,你需要有一个可以适应这个流的目标。 http协议没有。一个请求产生一个响应。 然而,你可以做的是将你的单个文件写入一个zip文件并将其返回给请求。

更新 但你真的想做的事:有你的服务器端准备在基于查询字符串的时间来创建一个XLS。然后在你想要抓取文件的页面中,分别为每个文件使用ajax请求,并使用html5文件api在本地回写结果。因此,不要试图在服务器上解决这个问题,而是将客户端放在司机的座位上。在那里您可以展示动画,对每个完成作出反应等。

+0

是否可以从xagent获得某种类型的响应,以便重定向来自xpage? –

+0

xagent可以写入作用域。 – stwissel