如何在ServiceNow中将带有图像的模板HTML转换为PDF?

时间:2019-05-24 13:40:07

标签: javascript pdf servicenow

我需要在servicenow中使用html模板创建动态pdf,但是我的问题是这些pdf必须包含图像和样式,而我却无法解决它。

尝试使用servicenow的GeneralPDF的api并将模板转换为pdf,但仅限包含文本的模板。当我放置图像时,出现以下错误:

执行我的代码时出现此错误:

  

ExceptionConverter:java.io.IOException:该文档没有页面。   org.mozilla.javascript.JavaScriptException:ExceptionConverter:   java.io.IOException:该文档没有页面。:

这在脚本include中,并从UI Action中调用 我将html转换为pdf的代码如下:

create : function (sys_id){ 

   var carta = new GlideRecord('x_solsa_casos_plant_doc');
    carta.addQuery('sys_id','6f1e4ac8db29f300ab7c0f95ca96197a');
    carta.query();
    if(carta.next()){
        var parsedBody = carta.body;
        var gr = new GlideRecord('x_solsa_casos_x_solsa_casos');
        gr.get('sys_id',sys_id);
        var sampleString=parsedBody.toString();
        var reg = new SNC.Regex('/\\$\\{(.*?)\\}/i');
        var match = reg.match(sampleString);
        var count =0;
        var variables = [];
        var values = [];
        var tmpValue;
        while (match != null) 
        {
            variables.push(match.toString().substring(match.toString().indexOf(',')+1));
            match = reg.match();
            values.push(variables[count]);
            gs.log("array values : " + values);
            if(gr.getDisplayValue(values[count])==null || JSUtil.nil(gr.getDisplayValue(values[count])))
            {
                tmpValue='';
            }else{
                tmpValue=gr.getDisplayValue(values[count]);
                gs.log("tmpValue :" +tmpValue);
            }
            parsedBody = parsedBody.replace('${'+variables[count]+'}', tmpValue);
                count++;
                gs.log("parsedBody : " + parsedBody);
        }
        this.createPDF(parsedBody,'x_solsa_casos_x_solsa_casos',sys_id,'carta.pdf');  
    }

},

createPDF : function(html, table, sys_id, filename) {
  var pdfDoc = new GeneralPDF.Document(null, null, null, null, null, null);
  this._document = new GeneralPDF(pdfDoc);
  this._document.startHTMLParser();
  this._document.addHTML(html);
  this._document.stopHTMLParser();
  this.saveAs(table, sys_id, filename);

},

saveAs : function (table, sys_id, filename){
  var att = new GeneralPDF.Attachment();
  att.setTableName(table);
  att.setTableId(sys_id);
  att.setName(filename);
  att.setType('application/pdf');
  att.setBody(this._document.get());
  GeneralPDF.attach(att);

},

1 个答案:

答案 0 :(得分:0)

看起来parsedBody是空的,或者并不总是包含HTML。根据这个答案,paseXHtml(ServiceNow可能使用它,并且应该在完整的堆栈跟踪中)期望HTML标记,而不仅仅是文本: https://stackoverflow.com/a/20902124/2157581