本帖最后由 James.Lv 于 2023-1-5 18:45 编辑
如果想要在业务系统中设置一个菜单,用户点击菜单时不经查看页面、直接下载和打印报表内容,可调用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
- POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
- HTTP-Header:Content-Type: application/json
- Body:{"query":"query { documenttypes(key:"rdl") { documents{ id, title } } }"}
复制代码 注意:外部调用API时需要在地址加上token认证信息
接着根据想要导出的报表的ID通过API获取到报表的导出地址
- POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
- HTTP-Header:Content-Type: application/json
- Body:{"query":"mutation { exportReport(reportId: "41ff202a-1868-41c1-8689-e8262fb52567", exportExtension: "pdf", renderPayload: {interactiveActions:"",parameters:[]}) { resultUrl, verificationUrl } }"}
复制代码 导出PDF不分页模式
- POST: http://localhost:51980/api/graphql?token=46911daf6f74fbb68ed0b0672a957cc17adc8aea3551d4f82018e80a753bc492
- HTTP-Header:Content-Type: application/json
- Body:{"query":"mutation { exportReport(reportId: "0ddb33e9-3211-4d96-9d25-ca34458dd8b9", exportExtension: "pdf", renderPayload: {settings:[{key:"IsPaginated",value:"true"}]interactiveActions:"",parameters:[]}) { resultUrl, verificationUrl } }"}
复制代码
注意:外部调用API时需要在地址加上token认证信息
最后在浏览器新窗口打开报表导出地址即可进行导出
- 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
- POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
- HTTP-Header:Content-Type: application/json
- Body:{"query":"mutation { render(reportId: "41ff202a-1868-41c1-8689-e8262fb52567", renderPayload: {interactiveActions:"",parameters:[]}) { jobId } }"}
复制代码 注意:外部调用API时需要在地址加上token认证信息
利用JobId获取到DocumentId
- POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
- HTTP-Header:Content-Type: application/json
- Body:{"query":"query { job(jobId: "d094e8e8-688c-45fc-8c13-e644114492f9") { status, documentId, error } }"}
复制代码 注意:外部调用API时需要在地址加上token认证信息
通过API和DocumentId获取到报表的预览打印地址
- POST:http://localhost:51980/api/graphql?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
- HTTP-Header:Content-Type: application/json
- Body:{"query":"query { job(jobId: "d094e8e8-688c-45fc-8c13-e644114492f9") { status, documentId, error } }"}
复制代码 注意:外部调用API时需要在地址加上token认证信息
最后在浏览器新窗口打开报表预览地址即可进行预览打印
- http://localhost:51980/api/workerJob/254680f7-c478-400b-be3c-800503ebb381?token=c8b21f18a1990baf5d73233f9530b7c22b803067041e43ef85ff892f7c894f38
复制代码 注意:外部调用API时需要在地址加上token认证信息
ReportTool.zip
(2.21 KB, 下载次数: 248)
|