如何调用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认证信息

原文地址:https://www.cnblogs.com/edoo/p/13900707.html