当前位置:  开发笔记 > 编程语言 > 正文

使用JasperReports将html内容导出为pdf

如何解决《使用JasperReports将html内容导出为pdf》经验,为你挑选了1个好方法。

如何使用HTML导出HTML内容JasperReports,我有一个带有HTML类型值的参数,我必须将其导出到pdf文件,其中pdf必须解析html内容



1> Alex K..:

为了在报告中显示html代码,我们可以使用由Jaspersoft开发的html 组件(正如我在查看源代码后所做的那样,作者是Narcis Marcu).

这个组件有很多限制,无论如何都不能为任何复杂的html页面提供帮助.无论如何,下面解释了如何使用这个组件.

借助iReport 5.6.0,可以轻松地将该组件添加到报告中.在Jaspersoft Studio(JSS)的最新版本中,由于某些原因,该组件已从调色板中删除.

iReport中Html组件:

iReport中的Html组件

使用JSS

如果你正在使用JSS,没有理由感到不安 - Html组件的支持仍然存在于Studio中.您可以在文件夹中找到htmlcomponent.jar,如下所示:Jaspersoft Studio-6.3.1.final\configuration\org.eclipse.osgi\38\0\.cp\lib\.

我们可以在JSS中使用Generic组件来使用Html组件的所有功能.

如何在JSS中添加通用组件

为此,我们应该至少设置Generic组件的几个属性:

通用组件的属性

通用类型名称应为:通用类型名称空间应为:htmlelement
http://jasperreports.sourceforge.net/jasperreports/html

我们可以使用Html组件的这个属性:

scaleType - 图像显示类型.支持以下值之一:Clip,FillFrame,RetainShape,RealHeight,RealSize

horizo​​ntalAlign - 水平图像对齐.支持以下值之一:Left,Center,Right

verticalAlign - 垂直图像对齐.支持其中一个值:Top,Middle,Bottom

clipOnOverflow

evaluationTime

evaluationGroup

JSS这个属性可以在组件属性的高级选项卡的帮助下设置:

在JSS中设置属性

iReport上,设置相同的属性要容易得多:

在iReport中设置属性

正如我之前提到的,JSS仍然支持htmlcomponent.如果你有带htmlcomponent的jrxml文件,你可以用与iReport相同的方式查看JSS中的所有属性.

使用htmlcomponent在JSS中为模板设置属性

使用htmlcomponent组件的示例

JRPdfExporter的帮助下,我们可以在pdf报告中显示这个简单的html页面.

HTML页面:




    Sample of html based report
    



This is a sample of html based report

Only minimal html features are supported

At least images are supported



Smile

我们将尝试使用htmlcomponent与帮助包装(本地组件)的HTML组件,并帮助通用组件.

HTML代码将通过报告的参数传递(htmlCode样品)

使用本机html组件组件.

JRXML文件:



    
    
        <band >
            <componentElement>
                <reportElement x="0" y="0"  />
                <hc:html xmlns:hc="http://jasperreports.sourceforge.net/htmlcomponent" xsi:schemaLocation="http://jasperreports.sourceforge.net/htmlcomponent http://jasperreports.sourceforge.net/xsd/htmlcomponent.xsd" scaleType="RetainShape" horizontalAlign="Left" verticalAlign="Top">
                    <hc:htmlContentExpression><![CDATA[$P{htmlCode}]]></hc:htmlContentExpression>
                </hc:html>
            </componentElement>
        </band>
    

使用通用组件.

JRXML文件:



    
    
        <band >
            <genericElement>
                <reportElement x="0" y="0"  />
                <genericElementType namespace="http://jasperreports.sourceforge.net/jasperreports/html" name="htmlelement"/>
                <genericElementParameter name="htmlContent">
                    <valueExpression><![CDATA[$P{htmlCode}]]></valueExpression>
                </genericElementParameter>
                <genericElementParameter name="scaleType">
                    <valueExpression><![CDATA["RetainShape"]]></valueExpression>
                </genericElementParameter>
                <genericElementParameter name="verticalAlign">
                    <valueExpression><![CDATA["Top"]]></valueExpression>
                </genericElementParameter>
                <genericElementParameter name="horizontalAlign">
                    <valueExpression><![CDATA["Left"]]></valueExpression>
                </genericElementParameter>
            </genericElement>
        </band>
    

在这两种情况下,我们都可以使用相同的Java代码:

Map params = new HashMap<>();
params.put("htmlCode", "\n" +
        "\n" +
        "\n" +
        "    Sample of html based report\n" +
        "    \n" +
        "\n" +
        "\n" +
        "\n" +
        "

This is a sample of html based report

\n" + "\n" + "

Only minimal html features are supported

\n" + "\n" + "

At least images are supported

\n" + "

\n" + "Smile\n" + "\n" + ""); JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JREmptyDataSource());

为了有效工作(报告编译),我们应该将htmlcomponent.jar添加到类路径中!

输出结果

两种情况的输出结果都是相同的:

使用JRPdfExporter生成的pdf文件


更多信息:

有关使用通用元素的信息 - JasperReports - 通用元素示例

Petter Friberg的答案很好:如何使用html组件导出带有嵌入图像(base64,data uri)的HTML文本?

可以在文件夹的JasperReports库包中找到htmlcomponent组件的源代码和使用示例jasperreports-6.x\demo\samples\htmlcomponent

另一个示例可以在JasperReports库包的另一个文件夹中找到-jasperreports-6.x\demo\samples\genericelement

推荐阅读
地之南_816
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有