OAF 中下载使用XML Publisher下载PDF附件

OAF doesn't readily expose the Controller Servlet's HttpRequest and HttpResponse objects so you need to extract it from the OAPageContext object via:

HttpServletResponse response = (HttpServletResponse) pageContext.getRenderingContext().getServletResponse();

Once you get the response object you could already manipulate its OutputStream.

public void downloadFile(OAPageContext pageContext) {
                                        
         HttpServletResponse response = (HttpServletResponse) pageContext.getRenderingContext().getServletResponse();
         
         File fileToDownload = this.createFile();
         
         String fileType = getMimeType("txt");
         response.setContentType(fileType);
         response.setContentLength((int) fileToDownload.length());
         response.setHeader("Content-Disposition", "attachment; filename=\"" + fileToDownload.getName() + "\"");

         InputStream in = null;
         ServletOutputStream outs = null;

         try {
         
             outs = response.getOutputStream();
             in = new BufferedInputStream(new FileInputStream(fileToDownload));
             int ch;
             
             while ((ch = in.read()) != -1) {
                 outs.write(ch);
             }

         } catch (IOException e) {
         
             // TODO
             e.printStackTrace();
             
         } finally {
         
             try {
             
                 outs.flush();
                 outs.close();
                 
                 if (in != null) {
                     in.close();
                 }
                 
             } catch (Exception e) {
             
                 e.printStackTrace();
                 
             }
             
         }
         
     }

 

 

参考资料:

Integrate XML Publisher and OA Framework

Downloading Files in OAF (需FQ)

XMLIntegrationCO

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以通过以下步骤实现EBS OAF多个头表数据通过TemplateHelper导出PDF并生成到一个PDF: 1. 在OAF页面上创建一个按钮或菜单项,用于触发导出操作。 2. 在后台处理程序,获取需要导出的多个头表数据。可以通过SQL查询或调用相应的API来实现。 3. 使用TemplateHelper类创建一个PDF模板,该模板包含需要在PDF显示的头表数据的格式和布局。 4. 遍历多个头表数据,将每个头表数据与PDF模板进行合并,生成单独的PDF片段。 5. 将所有PDF片段合并为一个完整的PDF文件。 以下是一个示例代码片段,演示如何使用TemplateHelper类实现上述功能: ```java import oracle.apps.fnd.common.WebAppsContext; import oracle.apps.fnd.framework.server.OAApplicationModule; import oracle.apps.fnd.framework.webui.beans.layout.OAPageLayoutBean; import oracle.apps.fnd.framework.webui.beans.message.OAMessageChoiceBean; import oracle.apps.fnd.framework.webui.beans.message.OAMessageChoiceBeanV2; import oracle.apps.fnd.framework.webui.beans.message.OAMessageStyledTextBean; import oracle.apps.fnd.framework.webui.beans.message.OAMessageTextInputBean; import oracle.apps.fnd.framework.webui.beans.table.OATableBean; import oracle.apps.fnd.framework.webui.beans.table.OATableColumnBean; import oracle.apps.fnd.framework.webui.beans.table.OATableRowBean; import oracle.apps.fnd.framework.webui.beans.table.layout.OATableLayoutBean; import oracle.apps.xdo.XDOException; import oracle.apps.xdo.oa.util.TemplateHelper; import oracle.apps.xdo.template.FOProcessor; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.sql.SQLException; import java.util.Iterator; import java.util.List; import java.util.Map; public class PDFExporter { public static byte[] exportToPDF(List<Map<String, Object>> headerDataList) throws IOException, XDOException, SQLException { // 创建一个PDF模板 String templatePath = "path/to/your/template.xdo"; TemplateHelper templateHelper = new TemplateHelper(templatePath); ByteArrayOutputStream pdfOutput = new ByteArrayOutputStream(); // 遍历多个头表数据 for (Map<String, Object> headerData : headerDataList) { // 将头表数据与PDF模板合并,生成PDF片段 ByteArrayInputStream xmlData = new ByteArrayInputStream(getXMLData(headerData)); FOProcessor processor = templateHelper.getFOProcessor(xmlData); processor.setOutput(pdfOutput); processor.generate(); // 添加新的页面分隔符 pdfOutput.write("\f".getBytes()); } return pdfOutput.toByteArray(); } private static byte[] getXMLData(Map<String, Object> headerData) { // 根据头表数据生成对应的XML格式数据 // 返回XML数据的字节数组 } } ``` 请根据实际情况调整代码,并确保在运行之前正确配置PDF模板的路径。此示例仅提供了基本的框架,您需要根据您的具体需求进行适当的修改和扩展。 注意:以上代码片段仅用于演示目的,可能需要根据您的实际环境和要求进行适当调整和修改。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值