REST APIでレポートを任意の形式(PDF、Excel、Word、HTML、画像)に出力するには、「/api/reports/{id}/jobs/render」APIを使用します。以下はJavaScriptでレポートをPDF形式で出力し、クライアントに保存する一例です。
(サンプルコード)
---------------------------------------------------------------------------------------------------
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
<script type="text/javascript">
// API実行に必要なセキュリティトークン。
//取得方法は「http://docs.grapecity.com/help/activereports-server-admin-11/#Get%20a%20Security%20Token.html」
var _securityToken;
// ActiveReports 11.0J ServerのURLを設定します。
var URI = 'http://activereports_server_url:8080/';
// 実行するレポートのID。
// 取得方法は「https://activereportsserver.zendesk.com/hc/ja/articles/115009896588」
var report_id = "xxxxxxxxxxxxxx";
var xhr = new XMLHttpRequest();
function RenderReportPDF() {
var Command = URI + 'api/reports/' + report_id + '/jobs/render';
var data = null;
xhr = new XMLHttpRequest();
xhr.open("POST", Command, true);
xhr.setRequestHeader("authtoken", _securityToken);
xhr.onreadystatechange = processResponse;
// 出力するフォーマットを指定します。「PDF」、「Excel」、「Word」、「HTML」、「Image」が選択可能です。
data = "{\"ExtensionName\": \"PDF\"}";
xhr.responseType = "blob";
xhr.send(data);
}
function processResponse() {
if (xhr.readyState == 4) {
if (xhr.status == 200 || xhr.status == 201) {
var blob = xhr.response;
var link = document.createElement('a');
link.href = window.URL.createObjectURL(blob);
link.download = "TEST_" + new Date() + ".pdf";
link.click();
} else {
// エラー処理
alert("エラー");
}
}
}
</script>
</head>
<body>
<input id="Button1" type="button" value="PDF出力" onclick="RenderReportPDF()"/>
</body>
---------------------------------------------------------------------------------------------------
0 コメント