zoukankan      html  css  js  c++  java
  • 如何调用Wyn Enterprise报表的打印和导出API

    如果想要在业务系统中设置一个菜单,用户点击菜单时不经查看页面、直接下载和打印报表内容,可调用Wyn Enterprise的导出和打印API,将报表内容打印或者导出为PDF、Excel等格式的文件。
     

    重点:Wyn Enterprise提供GraphQL API,几乎所有界面操作均可通过调用API完成,本贴主要介绍报表的打印和导出API,最后在附件一个简单的DEMO供参考
    实现原理:
    报表的导出重点分为两个步骤:
    1、通过API获取到报表的ID,并选择待导出的报表ID。
    2、通过API和报表ID获取到待导出的报表的导出地址,然后在浏览器新窗口打开即可导出

    报表的打印重点分为3个步骤:
    1、通过API获取到报表的ID,并选择待导出的报表ID。
    2、通过API和报表ID获取到JobId,利用JobId获取到DocumentId。
    3、通过API和DocumentId获取到报表的预览打印地址

    具体过程:
    1、报表导出(以导出PDF为例)
    首先获取到报表ID,通过HTTP-POST请求访问Wyn Enterprise提供GraphQL API地址,获取到报表清单,选择想要导出的报表ID

    1. POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
    2. HTTP-Header:Content-Type: application/json
    3. Body:{"query":"query { documenttypes(key:"rdl") { documents{ id, title } } }"}

    注意:外部调用API时需要在地址加上token认证信息

    接着根据想要导出的报表的ID通过API获取到报表的导出地址

    1. POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
    2. HTTP-Header:Content-Type: application/json
    3. Body:{"query":"mutation { exportReport(reportId: "41ff202a-1868-41c1-8689-e8262fb52567", exportExtension: "pdf", renderPayload: {interactiveActions:"",parameters:[]}) { resultUrl, verificationUrl } }"}

    导出PDF不分页模式

    1. POST: http://localhost:51980/api/graphql?token=46911daf6f74fbb68ed0b0672a957cc17adc8aea3551d4f82018e80a753bc492
    2. HTTP-Header:Content-Type: application/json
    3. Body:{"query":"mutation { exportReport(reportId: "0ddb33e9-3211-4d96-9d25-ca34458dd8b9", exportExtension: "pdf", renderPayload: {settings:[{key:"IsPaginated",value:"true"}]interactiveActions:"",parameters:[]}) { resultUrl, verificationUrl } }"}


    注意:外部调用API时需要在地址加上token认证信息



    最后在浏览器新窗口打开报表导出地址即可进行导出

    1. http://localhost:51980/api/workerJob/76054324-9bb7-4be3-a251-28a985497529?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38

    注意:外部调用时需要在地址加上token认证信息

    2、报表预览打印
    首先呢还是获取到报表ID,通过HTTP-POST请求访问Wyn Enterprise提供GraphQL API地址,获取到报表清单,选择想要打印的报表ID
    (上面报表导出已经说明,详情请向上查看)
    接着根据想要打印的报表的ID通过API获取到JobId,以及利用JobId获取到DocumentId
    获取JobId

    1. POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
    2. HTTP-Header:Content-Type: application/json
    3. Body:{"query":"mutation { render(reportId: "41ff202a-1868-41c1-8689-e8262fb52567", renderPayload: {interactiveActions:"",parameters:[]}) { jobId } }"}

    注意:外部调用API时需要在地址加上token认证信息



    利用JobId获取到DocumentId

    1. POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
    2. HTTP-Header:Content-Type: application/json
    3. Body:{"query":"query { job(jobId: "d094e8e8-688c-45fc-8c13-e644114492f9") { status, documentId, error } }"}

    注意:外部调用API时需要在地址加上token认证信息


    通过API和DocumentId获取到报表的预览打印地址

    1. POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
    2. HTTP-Header:Content-Type: application/json
    3. Body:{"query":"query { job(jobId: "d094e8e8-688c-45fc-8c13-e644114492f9") { status, documentId, error } }"}
    复制代码

    注意:外部调用API时需要在地址加上token认证信息 

    最后在浏览器新窗口打开报表预览地址即可进行预览打印

    1. http://localhost:51980/api/workerJob/254680f7-c478-400b-be3c-800503ebb381?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38

    注意:外部调用API时需要在地址加上token认证信息

  • 相关阅读:
    Java线程池使用说明
    Java并发编程:Thread类的使用
    深入理解Java的接口和抽象类
    编程中经常看到上下文context,这个上下文指得是什么?
    context
    setContentView和inflate区别
    Java for循环的几种用法分析
    Android学习06Android应用程序的基本组件
    learning java 重定向标准输入输出
    learning java 推回输入流
  • 原文地址:https://www.cnblogs.com/edoo/p/13900707.html
Copyright © 2011-2022 走看看